تعلم الأسمبدي 3281 


(الجزء الشاي) 


مطم6.٠‏ أده طانهم) لع/إ3 .لد مصخ طنالا :المع 
75 م 0115325678 :6 مملطم 


بسم الله الرحمن الرحيم 


الحمد لله رب العالمين و«الصلاة والسلام علي اشرف الأنبياء 


كنت منذ عام 2006 أفكر في عمل كتاب شامل لتعلم الأسمبلي 32 بت 
موجه نحو حديثي العهد بهذه اللغة .. ومن يريد تعلمها ولكنه لم يستطع ذلك 
لأسباب عديدة علي رأسها .. افتقار المحتوي العربي لدروس مسلسلة 
ومبسطة إلي أقصي درحة .. ولم أفكر في القيام بذلك جديا سوي في نهاية 
8 .. وخينها كنت أضيف: اليه كل بصعة أنامر شينا ما .. ولكنه توقف عدة 
مرات لأسباب عديدة .. أخرها لمدة سنة كاملة نظرا لقبولي ولله الحمد في 
الكورس التدريبي لمعهد 111 (تحية خاصة ل 12181630 المنصورة 5هملا 819) 
وكنت أفكر في نشرهة علي شبكة الانترنت للقاريء العربي قبل عام . . ولكن 
قلت لنفسي أنتظر قليلا حتي تجعله أشمل وتضيف إليه موضوعات شيقة 
أخري كنت أود الخوض فيها .. ولكن يبدو أنه كلما تأخر المرء ازداد كسلا عن 
ما سبق .. ولابد أن تأتي دائما دماء جديدة لتدفع العجلة كل حين وأخر ... 


ولهذا أكتفي ها هنا نظرا لظروف العمل والوقت الغير كافي لدراسة التقنيات 


الجديذة التي تتحفنا بها الشركات كل يوم .. وأترك الأمر لمن يأتي ويكمل .. 
وسأكوت تحعيذا لو أنه تعلعر يما ولو بنسيظا.من هذ | الكتاب. 


وقد قمت بتقسيم هذا الكتاب إلي جزئين كي يسهل تصفحه وأرفق بين 
يديك الآن الجزء الثاني. 


فقط نقطة أخيرة .. وهي بخصوص ال 01015 .. فقد اعتمدت أثناء تعلمي 
لهذه اللغة علي دروس كلا من 100اع102 و 110115 وأشخاص غيرهم قد 
نسيتهم للأسف .. وأخيرا مقالات كلا من 4/5 وأحمد غريب في موقع 
الفريق العربي للبرمجة .. الأثنان لهم جزيل الشكر قد دفعوني دفعا لتعلمها 
دون أن يدروا .. والشكر العميق كذلك لأخي أحمد الذي علمني كتابة البرامج 
ووضعني علي هذا الطريق. . وفي النهاية أشكر وأحمد الله علي خروج هذا 
العمل إلي النور واسألكم خير الدعاء. 


محمد فاروق 


أغسطس - 2010 





التنسخ وأدوات مساعدهة 


015 لتاأماعلط ع؛ مداع عتااء12 


1 - التنقيح في 30/8517] 
2 - برنامج /ع00لاطع0] لإاا00) 
3 - برنامج اع01ام<8 نان 
4 - أدوات أخري 





التنقيح وأدوات مساعدة الفصلء 1 





يقصد بالتنقيح 9179ولا06 هو عملية تتبع أوامر البرنامج عبر برنامج يدعي 
المنقح /0600006 .. ويساعد برنامج المنقح علي معرفة الأوامر التي يتم 
تنفيذها بلغة الأسمبلي .. ومعرفة قيم المسجلات عند تنفيذ أمر ما .. 
واستعراض المكدس .. وكشف وتحليل الملف التنفيذي.. والتغيير في شفرته 
ويساعد غالبا علي تصحيح الأخطاء .. وأشياء أخري عديدة. 


ويتيح 308517 خاصية التنقيح مدمجة مع بيئة التطوير وذلك علي الشفرة 
الموحودة بالملقات العضدرية... ولعمل. فقتل هذا السقيح قرحي تخمين ملف 
التعريف التالي : 


121110 0 : ١553055111503 51312 ١230© . 12 


ثم نذهب بالمؤشر الفارة إلي السطر المراد التنقيح منه .. ونضغط علي 
الزرين [41+158/] ونلاحظ ظهور مريبع احمر علي يسار السطر.. وتطلق علي 
تلك العملية (وضع نقطة توقف-]15أ0م31ع: 3 أع5). 


عاك ا ار ل ا الرا لر ل لرر ل ل للر ل ار 
2 قمع راممقع ماعن قنعو" مماعغصت دمت كاصم] عناتام غععرزصمع أختصمترمع سعلا عزمع عصاع 5" 


2 6 15 15 50 كه ىر | 26 لتنا لق 2 له لل لت 
لكت كله معشوصاءدداعطياك وي" | 
حا ا #0 


عمممع 2 


م 
َه | | اك 0 5-5 درسم رسيسوون اووس 


111 1_8 م ,111 لاط 


+ - © 0 هدس ةا س شظادرا يرن 
: ان ساة- س هاما 


هع د ارنا 
دارا 


ل[ 8111_5181 
اد:_111 2 ,111 لاط 
دده طهناف ها 
إعاو ناماس - اله اداه سس ادة- سات إن | 
اد:_111 2 111 اط 


اتطاضلر 1111لا وك انار نالك شاك مفخط عمعم عمعطوانا عجدعاع يه - حدم ذل"ا1 كتفت إععدزد 1 أوط 5 انقطك قت نا 





ونقوم بتشغيل البرنامج وعند الوصول التنفيذ إلي السطر الموجود به نقطة 
التوقف .. ستظهر النافذة التالية والتي تبين حالة المسجلات قبل تنفيذ الأمر. 
4 





























التنقيح وأدوات مساعدة 


علاطعل الأكخفل هما 


دش عدت 111 يي 222 
ل11 1111ل ل11لالانانالانا لالانانا نالل لالانانانانالانا 
انالا 
لانانانانانانانا 
لانانانانانانانا 
22 انا نا تالالا 
41111151نانا 
2828310 1 نالا 
1-012 اا 
221 الا 
15 411نانا 











م28 ععم0) برما 





نلاحظ منها مثلا أن قيمة المسجل“اة© هي [1118] نتيجة أن : 
111 نوع لم11 60_الا/نا 


وهكذا يمكن تتبع مسار تنفيذ البرنامج وحالة المسجلات .. وتصحيح أي أخطاء 





السك وادقات اه رة 
يعتبر برنامج 05لإ|ا0 من أفضل الأدوات الموجودة حاليا لتنقيح الملفات 
التنفيذية علي نظام ويندوز..حيث يتميز بالسهولة والمرونة في تتبع الملفات 
التنفيذية .. بالإضافة إلي خصائص عديدة يتمتع بها سنكتشفها سويا بعد 


لتنزيل البرنامج الإصدار الثاني من موقعه الرسمي : 
٠700.0‏ أ0. اناالا // :مخاطا 


بعد تنزيله وتشغيله ستجد الواجهة الرئيسية علي الشكل التالي: 


ماعط كشادلمصاتذ كصمصاامت ععقع1 ولطعن سبعالا عاع 





ددع 8 | ذْ [لأصعممداعمعل تعلصب - صملعيعب عاد العمرعام] تالا تم وطناباانا 


من قائمة ©11آا سنجد اختياران : 
الأوك 61م0 : وهو يستخدم لفتح الملفات التنفيذية6ص!|]0. 


الثاني 3626 : وهو يستخدم لتحميل الملفات التنفيذية التي تعمل حاليا 
من الذاكرة. 


نختار الاختيار الأول 0261 .. ونقوم بفتح برنامج تنفيذي مثل ©<030.6م00]6 
وبمجرد اختياره للفتحت ستظهر نافذة باسممر 30ع51] 11310 لا) وهي تعتبر 
النافذة الرئيسية للبرنامج.. ويمكن عرضها عن طريق الزرين[0+]41]. 


وهي علي الشكل التالي : 





الفغصك 1 التنقيح وأدوات مساعدة 


الت كار ارال انر لمارا ارللطنر - ]ا 2ت تر > لإدلل(|لف 
ماعاط 5ضدلطئبلا كصماعغمتة ععة1 ورطعن بعالا عاع إعا 


لهك املك لك تله فتك الداع كلداك 


2 
ذلاعع)_ مدع كمنوعة )| م “لجس 


اقنااع عد بي5 وق 8 .| 1اتظن 
إخانا 2 
18 )60 . تمه غخمم لاد 005 [ امم 315 938 3-3 
١ . 9 0‏ الم 6 21 0 0 
عوعرج ‏ معاع | باقه!" > . ققمع غخمدى بزع رولا 
02٠‏ . 32 اعاللامع كا > ] :5ن 8لم رابأزاايانا 0 ليالا 

- --- 0 لاع انان 
0 32 6 جه 2 جنك , لضع ] :05 _ كام 0 112 |4 


د 5-5 518273008 نلك علال 
)0 32015 عا 3+ #«مع] :05 218 80ثاليانا ,2ع لال 














١ 2326 
الالالا‎ 


اكت دزت ٠‏ || 7-68 نه 

: مه ح ‏ 06لا 27لا | 5 

01 51 601 81101 : 0 ال 6 |00 ثانا ثانا قانا 6 فام 4لا |0 ثانا ثانا انا 0 
الل” ٠:‏ إبانا | ا الال 1 1 86 8 أهت تاك تيك نات |16مت 
2 / - + أك 0-2 5 2 61 6 ان 55 هظ لم اأضض عت هه عك 2002 


العويروط] ْ عابكممم صتقمم أه أضادم تمصع 








© قسم الكود الخاص بالبرنامج ممتء56 6006©. 
© نافذة المسجلات وتحتوي علي : 
المسجلات العامة بأنواعها. 
© سجل الرايات 1305. 
مسجلات المقاطع كأدا560177. 
© قسم البيانات الخاص بالبرنامج 56100 0308 . 
© المكدس56366 الخاص بالبرنامج. 


قسم الكود : 
وهو يحتوي علي كود البرنامج بالكامل الذي سيتم تنفيذه. 


المسجلات : 
وهنو يحتوقف علي مفظعر مسدلات: الفعالة:.. وفتها مس حلات: الأغراض 
العامة .. ومسجلات العنونة والمقاطع ومسجل الرايات..ومن المفيد هنا 
أن تتعرق أكثر علي مسحل الرايات .. لأنه رتحكم بمسار تنقيد البرتامح 
للجمل الشرطية والتكرار .. وتستطيع منه التعرف علي نتيجة التعليمة 


ذا ما 
1 م8 
1 2 
نط 5 
هط [ 
8ط لا 
8ط لا 


التنقيح وأدوات مساعدة 


هو اكتثر راية مستخدمة في مسجل الرايات 
ويحدد إذا كان ناتج عملية حسابية أو عملية 
انتقال 516 نتج عنها محمولية بت ]لط أم لا. 
مثال 1 : 
عع راق /امما 
3-0 ,1 - طن , 1 راج 300 
مع 00 اق /املما 
00-<<3 ,0 - طن , 1 “3 300 
60 1360© لاج 
مثال 2 : 
“اط ,كلاق ملاع 
يتم هنا طرح المسج ل“ من المسجل«3 
فإذا كان [عاط<*«3] فلا يتم رفع راية 6 
وتصبح قيمة الراية صفر بينما إذا كان 
[ا>37] واحتاجت العملية استعارة //ا01101 
فيتم هنا رفع راية 1) وتصبح قيمتها واحد.. 
وكذلك الحال مع معظم شروط مقارنة القيم. 


علم التمائتل ويتحقق من الجزء السفلي 8 
بت من الرقم الناتج .. هل يحتوي علي بتات 
(من الواحد) زوجي ام فردي .. فمثلا إذا كان 
لدينا القيمة [58] اي [01011011] وهو 
عم 130 /1؛23 | يحتوي علي 5 بتات واحد .. فيكون ناتج الراية 
هنا فردي ولا يتم رفع الراية 
بينما قيمة متل ‏ [1]601 اي [01101100] 
تحتوي علي 4 بتات واحد .. فيكون ناتح الراية 
هنا زوجي ويتم رفع الراية. 


راية الحمل الإضافية وهي تستخدم 
للعفليات الخمانية القاضة (النظام العسدرف 
المشفر ثنائيا المعروف باسم /8183197] م86 
[0©611731 0ع00) حيث يتم التعامل مع كل 
وام رقم انه مكون من اربع خانات تنائية  (‏ ©0656 
00 يم | عاطططاه) مستقلة .. فمثلا القيمة العشرية 
لكر [156] ستمثل بهذا النظام علي هذا النحو 
[ 0110 0101 0001] ويتيح هذا النظام تمثيل 
التظام العشترئئ ثنائيا في الفعالج ‏ :وتمكين 
القدالة قن الغدامر ىر عه اانه عنسا بده فلن 
قيم عشرية ويوجد تعليمات مخصصة لهذا 





التنقيح وأدوات مساعدة 


النظام ولكننا لن نتناول هذه التعليمات هنا.. 
يتم رفع راية الصفر إذا كان ناتج العملية صفر 
والعكس ذا لم يكن الناتج صفر 
مثال 1 : 
1 ,»0 /الا 
28-1 ,20<ين , 1 ,»0 الاك 
0 ماع72 | مثال 2 : 

“ا 3 ملاع 
يتم طرح المسجل “ا من المسجل 3 فإذا 
كان الناتج صفر أي [“ا6-“«3] فسيتم رفع 
الراية #1 والعكس. 


راية الإشارة يتم رفعها وتكون فيمتها واحد إذا 
كان ناتج العملية رقم سالب ع031(06ع١‏ .. 
بينما تكون قيمتها صفر إذا كان الناتج قيمة 
موجبة .. وكما نعرف فإن الإشارة يتم 
تحديدها من البت الأخير ( أعلي بت هو بت 
الإشارة ) في الرقم. 
مثال 1 : 
- 230 مواك 0 ,»0 01لا 
52-1 ,1--»0 , 1 ,»© الاك 
52-0 , 1-)»0 , 2 ,“6 300 
مثال 2: 
“اط ,كلاق ملاع 
إذا كانت ناتج طرحد “6 من 37 هو قيمة 
سالبة فسيتم رفع راية !5 والعكس. 


وهي راية تحكم تتيج للمنقح ان يتتبع 
البرنامج بجعل المعالج ينفذ تعليمة واحدة 
15 51360 م3١1‏ فطل امسو عاء ماطف ها 


وهي راية تحكم تستخدم لتحديد اتجاه 

التعامل مع الذاكرة [2011/5 06 (ملا] وذلك أثناء 
0 0 ا[التعامل مع تعليمات النصوص .. حيث توجد 

تعليمة لرفع تلك الراية وإنزالها .. فإذا تم 


رفعها فهذا يشير إلي أن التعامل مع الذاكرة 
سيكون .من الذاكرة الأعلي إلى الأقل 





التنقيح وأدوات مساعدة 


5 . . وإذا تم إنزال الراية فهذا يشير 
إلي ان التعامل مع الذاكرة سيكون من 
الذاكرة الاقل إلي الاعلي وهو الافتراضي. 





ويتم رفع راية الفيض في حالة إذا كان ناتج 
العملية الحسابية أصبح كدو قن الحجم 
المخصص لاستيعابه. 
لازقااروت91. كْ 
0 وداء نال : 
7 ,اق /املما 
: 1 راج 300 
8- ,اق ناملا 
: 1 ,اج طناك 


وتعلينات القفز الشرطية تقوم باختبار الرايات السابقة تبعا لنوع التعليمة ومن 
ثم تنفيذ القفز أو عدم تنفيذه تبعا لقيمة الراية. 


وتنقسم شروط القفز إلي ثلاث أقسام : 


القسم الأول : تعليمات القفز التي تختبر الرايات 


سياه 


. 35 1 601590نال | 586221 |  -‏ | 5لا | 


. 25 | 00065986 /1م0ن1 | 52-0 |  -‏ | 5 ا 
. 10 00/100 ]1 مصنل_ | 08-1 | - | 100 | 
30 00ع/0 ول١!‏ ]1 مون | 08-0 | - | 310 ا 
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الفصك 1 التنقيح وأدوات مساعدة 





القسم الثاني : تعليمات القفز للمقارنات الغير مؤشرة60 5101لا 


1<-ط) 
اط 


اط 
1<طر) 


1-1 
21-0 


مقطا ودع| أ10/ظ 11 ملانال 
[ >!] 
01 تلاقطأ 5دع1 !1 متانال 
[->] ا3لامع 
مقطا ودع| أ10ظ 11 ملانال 
[ ->!]|3نامع 0 
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التنقيح وأدوات مساعدة 





طريقة التحكم في مسار تنفيذ البرنامج : 
يوحد بالقائمة وناطع0 الأوامر التالية : 


ماع عسضمومبذ كمصاعامت ‏ عددم[] بسع" عاع زعا 


وع مع 2 |4 وهاه 





11 ندع راع مريا 22 

د لالم 

+1 1 اداع 3 “رح عاتم 
تائم 


لا لوا ا 1 ات 
لم1 ائا لكا لها 

سي مور سيرم 

لذا لكا أ 


إدلد 


وعد اما لطعم أأنا عطالدمععع 59 


- ل 


ل- 


نيعب ]من رخ ادوع م 
تعب تر عدد | 


سل سن اسن لسو سن سور سن سور سر 
الما ذا اذا اذا ذا اذا ذا اذا اذا 1 
ا ل ا ل ل ل ا 

الخا ذا لكا لكا ذا نذا لهذا ذا لكا ل 


تت 
متا 
0 


1 


مع ماما معاد 8 
ع عات معاد 0 


ا 1ر1 ار 1 122 اك الك كل 








فوق الروتينات الفرعية وتنفيذها مباشرة 8 اع/ا0 مم51 
والعودة بدون القفز إليها. 


صادف التنفيذ نقطة توقف ]أ0أ00)ا هع 


ويمكن وضع نقاط توقف 81631001055 علي الأسطر عن طريق الزر22 .. 
ولالعاتها أنضا كي الصفعا على :تقس الزد 





وهذه قائمة ببعض الاختصارات المغيدة : 


١ش‏ 
غ+ انان يقوم بتحرير ]2501 بيانات السطر سواء أاسكى أو بيناري 
م815 +غام يقوم بالتراجع 000لا عن ما تم إضافتة أو تغييره أو حذفه 





لا + انان يظهر قائمة مهمة جدا بها جميع اسماء وعناوين الرموز 
المستخدمة في البرنامج 
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مر 


لفص 1 


التنقيح وأدوات مساعدة 





النام كار ارا لوول )| ف 12 ا كار © درلل لالش 


ماع كستملمئتك خصصغصت خعت2] وبطعنا سبعانا عالع ل 


مااع | امه اع له اله انرااتط |:* انك إلااع اع [ع هه ها 


< لاعنامعلما_دلانا_عحات1 11 

+ عنانا! نااحا1 1_5 1ا_عتات1 1 

+ اعلا طلنما_ع 1٠‏ ع_عتات1 1 

+ لاعنلانعطلم_اناةانا 1 1 الا_عحاض1 1 
2 انان ] اع 1 لاق | نلا_عحات1 11 
< تاعلاناع 1_1 الا[ اناعط_عتاض1 1 
< تاعلاناع 1_1 الا1 اناعط_عتات1 1 


فمثلا إذا أردنا معرفة مراجع 


الفارة الأيمن واختيار الأمر 


ك1 1 
ات 
رام عنم)ا_لانا1 اناعكط_ع تام 1 
تناع 1 طناططنا_[ا طلا 11 _لالالاناع_ع حاتم 1 
انا م 1 لطناططنا_ ا طلا 11 _لالالاناع_ع حاتم 1 
انا 1 طناططنا_اطلا11_لالالاناع_ع حاتم 1 
انا 2 1 طناططنا_اطلا 11 _لالالاناع_عحاتم1 1 
انا 12 طناططنا_اطنا11_لالالاناع_عحاتم1 1 
انا 1 طناططنا_اطنا11_لالالاناع_ع حاتم 1 
بانا 1 م 1 طناططنا_اطانا11_لالالاناع_عحا تم 1 
تععط_عطناعملاعنباعط_نالالاناع_ع حاتم 1 
انا 1 طناططنا_اطنا11_لالالاناع_ع حاتم 1 
انا 2 1 طناططنا_ا د11 _نالالاناع_عحام1 1 [نالا| > 
لباسعع بدا دارا يحزه ماوع , 2د 
بع نادت ا ناوعط م عت [ عملا ارامت 
لايع ماء دع ناو عط معد [ عملا ار]انة 
عتدح ] لملاعبع | 1 معد زعملا ارامت 
عع با دارا يزه بمستاوعط ,م عت [ عنما ارامت 
لرببع رح محص ادجعع _ نات زر عبنار لبرت 


يقوم بالبحث عن جميع المراجع في الكود للعنوان المؤشر عليه 
لاع>اع0)0105ع! في الكود .. نقوم 
بالضغط علي 11+0]) واختيارها من نافذة الاسماء .. والضغط بزر 
5ع لاط من القائمة 


عودلم 
آ1عالاك | 5ه 
[1تغالا8 | 5ه 
[1غالا8 | 5ه 
[1غالا8 ]5ه 
الا 5ه 
1غالا8 ]5ه 
1غالا8 | 5ه 
الا 5ه 
1غالا8 ]5ه 
الا | 25> 
الا 25> 
تالا | 5 > 
الا | 5 > 
1لا | 5 > 
تالا | 5 > 
تالا | 5 > 
الا | 5 > 


[ عملاناقة 


عمب 1 
عزعت ب ] دمم 
عزعت ب ] دمم 
عزعت ب ] دمم 
عرزت ب ] دمم 
عزعت ب ] دمم 
عزعت ب ] دمم 
عزعت ب ] دمم 
عزعت ب ] دمم 
عزعت ب ] دمم 
عزعة ب ]ا دمم 
عزعة ب ] دمم 
عزعة ب ] دمم 
عزعة ب ] دمم 
عزعة ب ] دمم 
عزعة ب ] دمم 
حزعة ب ]ا د مم 
عزعة ب ] دمم 
حزعة ب ] دمم 

#ختصصط 1 
#ختصصع 1 
#ختصصط 1 
خنع 1 
#ختصصط 1 
م1 


0ص]ا عدعهد 


لت يورا ساس" 
اتات اتات 1 م 
ضاع تتطاتطت 1 م 
ع اتات 1 م 
حا تاتاتطات 1 م 
152 تطتطات 1 م 
-01] 1 تطتطت 1 م 


عاناتصتة ضاكخد أت أضامم ماصع 


المنسدلة أو نضغط علي+© 


لتقمعامن نآ ععتمدلة 


ع0ذا؟ | 2م19 | ممزعع52 | _عدعصددمر 


در اطناع11_نالالاناع_طاحاك1 1 [انالا 51> إعرعدب| دمم 
إياببعت ب ا كارا يمرك بلماوعط ‏ عت [ عبار ارام.ة 

بعتاعده | ناوعط . تت [ عابرا ارام.ة 
إباسع ماع عد عع أوعط ‏ عد [ بارال نيع 


حا سس اسلا لسريس اس 1 نك 1 نطئرا المتلكرب 


غية 


“انالك 1 نات هعنم 


وستظهر لدينا نافذة بعناوين استدعاء تلك الدالة 


الك ...ة5ماغيع!!. 7ةاتاق لاناظمء م1 وععمعرعاعا 


ل ت بمناع حد ا امعط . 32 1 عنلاناناية > | :ذئنا 2158 نانالالانا لالانا | كد احنات 1م 
لم ومذاع كخد ا نامعط . 22 1 نل انالاءة > ] تئنا 118 نانالالبانا للانانا | 2 اتات 1ات 
[ ث سمخاع حد | ناوعط , 22 1 نل انالاءة > | :ئنا 18 نابالالبانا الانانا | لقاعم نات 1 ات 


تت ترم عام 3 تتبيمدع 


8+ اننم 


ا+انن 
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البحث للاماماناء/ا! 563101 ويمكن استخدامه للانتقال للمرجع 
التالي عهمعععأع5 )اعلا 





التنقيح وأدوات مساعدة 


ا+طك+ انان البحث للخلف ع©5)ع/1ع8] 563121 ويمكن استخدامه للانتقال 
للمرجع السابق ع60مع0ع1ع] ونام أ/اع ]م 


51+6© | يقوم بإظهار نافذة تمكن الانتقال إلي العنوان الذي تحدده أو إلي 
اع3!ا محدد. 
053 الاك ل لراك تارك 4ت رتازرة 
3901م انا الا 
[ ست 


يقوم بعمل 0006© 4319/56 حيث يحول الشفرة بيناري إلي بيانات 
وتعليمات اسمبلي 

يقوم بإعادة تحميل البرنامج المراد تنقيحه مره أخري. 

يقوم بغلق البرنامج الذي يتم تنقيحه. 

يقوم بإظهار صندوق حواري لفتح ملف جديد. 

تكبير أو إرحاع حجم النافذة الحالية. 

يقوم بجعل نافذة البرنامج في مقدمة النوافذ 001005]6]. 

يقوم بإظهار نافذة بها قائمة لجميع نقاط التوقف 2 5أ6أه0م)>اجع/8 
الموجودة بالبرنامج.. ويمكن التحكم بتلك النقاط عن طريق الزرين 
ع36م5 و اع0 .. حيثف ©5036 يجعل نقطة التوقف نشطة أو غير 
نشطة .. وا©0 يقوم بحذف نقطة التوقف. 

يقوم بإظهار نافذة بها قائمة بجميع الموديولز 101065 التي 

يبقوم بإظهار نافذة 09ا بها معلومات إحصائية مهمة عن البرنامج. 

يقوم بإظهار نافذة م113 1167001 وبها بيانات البرنامج في الذاكرة. 

يقوم بإظهار نافذة 061005 للتحكم في خصائص برنامج 009 /[|01. 

يقوم بالانتقال إلي المرجع السابقع60معع86)6 رمعم 

يقوم بالانتقال إلى المرحع التالئي6©6مع/266 غزه|١‏ 

يقوم بنسخ التحديد إلي الكليبورد003]0مزاء. 

يتتبع قفزة أو استدعاء. 

يظهر نافذة بها سطر الكود المجمع. 


8+ انان يقوم بإظهار نافذة تستخدم للبحث باكثر من صيفة (السكي 1 
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المت واذوات مساكدة 


لاا زكرت راتتزرفا 


ااداكثت 
غنانانا لكالا 
لالا+ #تع نم 


5 


عاعداط فصع 5 :لادردعدك 
لمخشضودع مم 
تدسناءد 8 ) 


لفصل 1 
ا+انان يقوم بإظهار نافذة تستخدم للبحث عن تعليمة محددة يتم إدخالها 
| 05آ+ان 6‏ 


يدويا. 


الاك رتت رت شت اك 


تأعصاط عراضصع 5 :تاتردعدك 
لرخضرمع © 
تمدضنئاعة 8 ] 


1+5) | يقوم بنسخ التحديد الحالي بصورة بيناري لام0) /510319. 
يقوم بلصق ما في الحافظة من بيانات بصورة بيناري عند العنوان 
الحالي غ235 /319ا8. 
استخدام ال 0100© 5/71 يتيح إضافة تعليق علي سطر التعليمة. 
| :2-5 |يقوم بإضافة اع30| عند العنوان الذي تحدده. 
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التنقيح وأدوات 


مساعدة 


تطبيق عملي : حقن كود وتنفيذه. 


1 - نقوم بتشغيل برنامج/!06600006 لإاا0 وفتح برنامج ع“اع.30مع101 
الكود ونجدها 15 الالاا .. ويطلق علي تلك المنقطةع/7١3)‏ ©00). 


ناتك ار!) ارااناررات لكا - عماة. لمتمرع1مم - واثاراان 


علد اك طايه 111نم 
,""لنام"” 5111م 


تان غلا 


م 1 لبانا 


ام ""لبا بنك | سادك مإ لباغعحا"” 1 1 ناكم 
اتن _ غلا 


كينا | اس كل ااه 


51 كه حم تك 
تام ”5 لاك 


عنام 
”مرك خث طم مرك 
ثاثا 


لالكث ختاات 1 اتا 
عاك داتات 1 قا 





3 - نقوم بتحديد 10 بايتات (أي 10 عناوين) من العنوان [01008747] 


ضم"" 1 ال .لطع طلا" 5111م 1[ 2ط كك 5ط طط 


1 اتات 1 انا 
”م اتا 1 انا 
كم اتات 1 انا 
كم اتات 1 اتا 
نك اتات 1 انا 
عكم اتات 1 اتا 
الى اتاتتا 1 انا 
ناكم اتات 1 انا 
عاك اتات 1 اتا 
عك” اتات 1 اتا 
تاك اتات 1 اتا 
1 5 :“اتات 1 انا 
كم اتات 1 انا 
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الفصك 1 التنقيح وأدوات مساعدة 





القائمة المنسدلة الأمرغ01 ثم غ01 /1ةما8. 


5 - وستظهر نافذة لتحرير ال 10 بايتات المحددين سلفا .. نقوم بكتابة أي 


كلمة بهم ولتكن "128110" ولكن سنقوم بكتابتها يونيكود وليس اسكي 
وذلك لان الدالة التي نستخدمها لعرض الرسائل /للالاماع5530ع/ 


تستخدم الإصدار الموسع 1/106 لعرض رسائل لحروف نصية بكل اللغات.. 
والحرف في نظام اليونيكود بحجم2 بايت..والبايت الثاني سيكون بصفر. 


747 1008 لتمعامم ؤو5ع:ل30 1ه متهل 11ل0] 


آنآ 1 ال |اناكث 
05 غنالانا لكالا 


0 *421 0 عاك تالا 0ك انا 5ك فالا 4ك شلاء ممعم 


ثانا 


ظ إععمةنا عداة مععةا | 


ثم نضغط»01. 





6 - بعد الضغط علي 01 سنعود إلي نافذة 11310 لا8© سنجد ال 10 بايتات 
تمت إضافتهم علي النحو التالي : 


عم"" 1 1ك .تت طططلا"" 1 1نا5كم 1[ مط كك خط طط5ط ا ٠‏ |10اتم طتمات 1ت 

#لاع ماعنا 1ك كم امات 1 اتا 

انام ل عع ] :55 لام عالزع الات تان ك45تات كم امات 1 اتا 

2ه مانا الك عك” اتات 1 اتا 

الامرزعكء مننرع+ مقع ] بجنا لام عالاق اناك عاك تاتم_اكتات الهم اتات 1 اتا 
انام لث تنلاع ] :طلا 8م ط[الاع نالاك تاتاتات ناكم امات 1 اتا 

تناتا لا عات خط امات 1 اتا 

نات تنا اتا 3ط اتات 1 اتا 


7 - نقوم بالضغط علي 07181+8© للأسطر المحددة .. أو بالضغط بزر الفارة 
الايمن ونختار ©00) 9/56إ|43 < ؤأولإ|83 .. وسيكون ناتج تنفيذ هذا 
التحليل علي النحو التالي : 


ضم""٠‏ ا .تت تطعذلا"" _ 11 تاذل 1 عط _ كك 3ط طط ‏ ع إناتم اتات 1اتا 
صضم""نللاع"" عنانانا11الا انالك تاطكك قاقططك ‏ - إمخ+”م ل اتات 1تا 

تاك تنا تاه طم اتات 1 انا 

ثانا انا تايا كط جتاتا 1 اننا 
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التنقيح وأدوات مساعدة 


وقام البرنامج بالحاق بايت ا الالاا في أخر النص ليتحدد نهايته. 


8 - سنقوم الآن بكتابة كود يقوم بإظهار رسالة نصية .. وكما نعرف نقوم بدفع 
ولا .. فنقوم بتحديد 2 بايت بعد الكلمة 0 ااع ١1‏ . 


0 





معاملات الدالة 


ضم""*1 ال .اد قط طلا" 5111 1[ 52 كك 525 ط5طط 
ضام "لاللاعم"" علا 1ك الك _تاتاكك 0 


9« :ثهر تففط غلى حرق المنساقة 56366 أو بالضفظ ترز القارة الأيفن: واختيار 


الأمر ©25561101.. وستظهر النافذة التالية: 


[ ته 





0 خقوم بدفع المعامل الأخير للدالة “1165530680 وهو [0 لأاؤ5لاه] .. ثم 


نضغط علي عاط7اع655. 


اتا 
اتا 


تام,""٠‏ 1 .تتتع ذلا" 11نا5ل 1[ 2ط كك 553 طط 
ثم ""تلالاعا"" علنانا 11لا اناك تاضكك تامدك 
م أذ5لاط ات نات 


ثاثا غلا ثاثا 
ناث انا عاتم 

1 خم نقوم بتحديد ال 5 بايتات التالية : 
ت,"” 1 21 .2ت ططكلنا"" 5111م 1[ نط طك 3ط طط 


ننا,""لاللاعط"" عالانا 11لا اناك ية 2 - 


كت لاذلاط ناك 
ثاتا نا ثاثا 
تاها غلا ثاثا 
ثاتم تنا ثاثا 
تتا غلا ثاثا 
تتا غلا ثاثا 
ثانا غلا اها 
ثاتما تنا اتا 


3 ؤنقومر يدفة غنواثت الكلمة 
الرسالة. 


1م اتا 1 اتنا 
ك” تتا 1 ائنا 
25 اتات 1 انا 
5م اتات 1 انا 
ككثم اتات 1 انا 


عا نا مودعم 


قلعا ناك” ثدلانا انا 


غداة معفة | 
دل 4 خلازس ااع مم 


لذا لا نذا نذا نذا 
“كك اك كلظ اك كا 
لذا لا لا ذا نذا 
لذا لذا نذا نذا نذا 


لا نا تلا نت اتا 


مم الماتط 1 


252 اتات 1 اتا 
259 امات 1 قا 
ناكم امات 1 انا 
طم اتات 1 انا 


"0ااع0" وهو [01008747] كعنوان نص 


التنقيح وأدوات مساعدة 


عا اتمعوعم8 


م ساكس أك انا انا 


عداء معص م | 


ظ دا ود لال" طالب إأزع مما 


3- نقوم بفعل نفس الشيء للخمس بايتات التالية .. حيث نقوم بدفع نص 





الرسالة. 
,"” 1 1ك . حت طعذلا"” 5111نم 1[ 2ط طك 2ط طط ا اه (2الح” اتات 1 اتا 

تا,""لللااع"" عنالناا11الا اناك تغتططك تاتا كك - إث ك” ل نات 1انا 

لاإدلام تنات ناث طم نات 1 اتا 

""زاللاعص"" علا لان 1لالا “ات م 1 , تدمع عدم لإاذلاع | 1تامصضص” حك ذم ططث تنام 1 اتا 
""لاللاع"" علا لان 1 الا “لت ا 1ت , قمع صم للأذلان | 1 عطضت د" 4ك دض نرط” اتات 1 اتا 
اتا الا عاتم عاطم اختاتط 1 اتا 

تان تنا عاتم ناكم اتات 1 اتا 


4- نقوم بتحديد 2 بايت تاليين لنقوم بدفع مقبض النافذة المالكة للرسالة.. 
ونقوم بدفع القيمة صفر لها. 
,"2.211 تمعطذنا"” 1 1ناكم 1[ 2ط طك دط ا طط ‏ هه إا 
ثا,""لللاع"" عنانا11الا اناك تاضطك تافدك ‏ عه إ|م 
تت ادزام ثاتك لاك 


3 

""لاللاعط"" عنالا 1 لملا كت اتات 1ت , كمع خصم لأذلاط | 1 تاقطص” ذم ك ذم 5 
""لالللاعط"" عانانان 1لالا #_ك” اتات 1 تا . لكجمع خصم لأذلاع | 1 تافص دمك ذم : 
كه لاك تاثا 1 

َّ 


لكا لكا لكا لكا لكا نكا لكا نكا 
موعشرعوعمريوعر تزيم 
ذا اذا لوا ذا ذا نذا لكا لوا 
ذا نذا لوا ذا لكا ذا ذا ذا 


نا نا الا لا نلا نلا ناا 


5- الآن نريد الحصول علي عنوان الدالة “«11©5530680 ..نقوم بالضغط علي 
[[781+8©] للحصول علي قائمة بأسماء الرموز .. وفي القائمة نجد أن الدالة 
ليست مستوردة .. ومن الممكن إتيان عنوانها واستخدامه 
مباشرة .. ولكن ايضا من الممكن استخدام الدالة /الا»ا80ع15530 التي 
يستخدمها برنامج ١/0130‏ لعرض الرسائل .. ومن النظر نجد ان عنوانها هو 
[01001268] 





19 


التنقيح وأدوات مساعدة 


لساك النلس تللكان ارا تلرراءلئ]| لخدت 1ع تانر > للدإدرل 0ه 
* اكأق | ماعط كبتتدلمائت كصداامتث جع3غ1 وبطعنا] سعائا عاع |1] 


اليك الع اال :+ ةك إلااع اع إعا |هه ها 


عمت ل عمبا] | مصاععع8 | حدحع تدم 


معت عدبرمعلاععدا , خط عادااابة اعنحعطه 1 برع ع , تطح 1 اتا 1 انا 

مع ع [ بسمعلاع | طدومع عط عادلاءة اختحعه 1 برع 2 . أإناطك 1 نات 1 اتا 
ادك اط بكدععدا . خط عادااءة انتحع1 + برع ع . اتاذت 1 لاط 1 كا 

لامع لاععد . عطط عادال اب احنحعه 1 + ببح ع , جحت 1 اتا 1 انا 

الاجدععود ددع 1" . خط ادل اختحصطم 1 بجع 2 . اكت 1 تالت 1 كا 

لاد محاسدت ما لاععد . عحخط عاداابة اختحعطم1 برع 2 . إناحت 1 تا 1 اك 
لاد محاسدتك ما لاعع دا . خط عداابة اددع 1 بنع 2 . اتتت 1 نات 1 اتا 
قمع 312الاععدا . خط ادل 8 اختحعه 1 خبرع ؟ . الجثمت 1 تنا 1 اتا 
مدع ععد تحط اد 8 اختحعط1 برع 2 . اكت 1 نات 1 اك 

ااعمحجا ومع ع لت اراععة _ عدم لتم | م1 «#بج عر الل“ نمم ام 


العوبقص] | عااقدكم ضاقمم أت أضادم ماصع 


ورالتالت لا سكديا غنينا اسستدعاء هذ العنوات يعن مقطغ اليانات 05 حيت 
يوحد جدول الدوال المستوردة 





[55:]1001268 18م موم/لاه لامع 
فبالتالى تقوم بتخديد كمس بابتاك لكنانة تعليمة اسغدهاء الذالة يوم 


ضم""* 1 ال .د قصط طلا" 11ناكم [ 52 كك 2ط طط ا اع إناتم اتات 1ام 

ضم""للالاع"” علنانا 11لا اناك تاططك تافعك  ٠‏ إ|مك” اتات 1ت 

ته لاذلاط مات ناك 252 لمات 1 اتا 

مث اتات 1تثا . كمع خصم لأذلاط | 1 قاقضاقم 8مك دم ططث كات 1 تا 

ى” اتات 1 تا , قمع غصم لأذلاط | 1 ناطظ” 5مك 53 ناك اتات 1 اتا 

كه لاذلاص نات نات عاك اتات 1 اتا 

ل لبا بصع وده :م1١‏ . تتططذلات ‏ ا قطنا 218 لاثانالبانا_ الانانا | تاضض2 521 طاعع 1 اتات 1 ايا 
ثاتم تنا تاثا “ةقث اتات 1 اتا 


6- لدينا الآن عنوان بداية تنفيذ الكود المحقون وهو [01008/753] وسنقوم 
الآن بمعرفة نقطة البداية 0161/0016 الخاصة بالبرنامج وتغييرها بعنوان الكود 
لدينا حيث نقوم بالضغط علي الزرين [/1+]41] لإظهار نافذة م113 /إزهططاع71 . 

ثم نختار العنصر !١163061[‏ غ2] الخاص ببرنامج 30م]1/0 ونقوم بالضغط عليه 

مرتين بزر الفارة الأيسر. 
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التنقيح وأدوات مساعدة 


"١ 1‏ ملع ابل 


00 
00000 
00 
ع1 قط 601 810 


عزعتدعط عم تدمع غدم 

3 دمن | رعتكدنا ٠أ|)‏ تتمععغدم 

عيه مدنا ليا | وم 1 5 +5لا .)| تتمعغدم 
- ان ل 2 





فستظهر نافذة بها قائمة نختار منها 011 لأ 200155012 


3 نكالحا لكا با للا ررك جد اط تتازنلر 2 لنإد ال الف 
2 ماعط كعشصكمائت؟ كمداعغصفت جعقغ1] ونباطعنا سبع عالزع زظ] 


لمك لعلسرع ته الك ناا |:* ات لاا اع عا |هه اها 


معمنردنا ود دك دعتدععنا منريكت بعل | ددع نودم 


ص رضدتقعك - د5غؤدناده 12 1 دا 1 م[ #لاع ع ] 5 | فضضهم مضنت تاتاتات ناتاه عاتم 1 اعالتاات 1 انا 
:. ع _5غ<ةلات2 12 اا ١+‏ نأا مال لاك ع 5 | ضام مدصصمنتم اعاتاتط نم انان _ ٠‏ || كنا 1 قالعاات 1 اتا 
١‏ لم239 - عاأمادنا بحر ومع ناكد ع 0ه | لتم ممصمم تاقاقات” ناك ٠‏ |]13-3تاتات 1ت 
تثاتاه 1 - دمعصناءع لاع ددع | ناضت [ نافتات اثاتاتات 1 نان 2 ٠‏ | ]اتا 1 تالتات 1لا 

تتا - 1515| +لاء ددغ | تاتاتات امامت تاقاقط م2 ما ٠‏ |10 1 اتات 1ا 

ماتاتاتثاتات 1 - عددط دن [ | تاناتاتاتات 1 م انعاتاتا ته نالطن _ ٠‏ [(إك 1 1تالتااط اتا 


غييه 
العوبقص] | عااقددم ضاقمد أت أضادم برامصع 


حيث نقوم بالضغط علي هذا العنصر مرتين لتظهر النافذة التالية: 





56 ...010ل دمعتمم نه لعمسف أتلع 


ماعل ناكا اجممرععةدمع لا 


00017 لع اواك 


007 دعضواعصلا 
| ا#ست 





نحفظ العنوان الأصلي [7390] لدينا ثم نقوم بتغيير القيمة إلي العنوان 
التسيى لبداية الكود المحقون] 8753], 
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التنقيح وأدوات مساعدة 


56 ...010.لممعامم نه لعدييق اتلع 


0011| أقمماح ودع لا 


10 كدوك 
10 نعصوعة دلا 


اديت 





ثم نضغط 01 .. ونذهب إلي الكود المحقون .. ونضيف الأمر التالي بطول ‏ 5 
اينات في نهابة الكود للعفر إلي نوات تقطة بداية الكوذ:الأصلي. 


010073910 الال 
وستكون الكود النهائي علي الشكل التالي: 


,"232.211 تططلا"" 11ناكم 1[ 2ط كك 2ط طط ٠‏ إناكم اتات 1 اتا 
تعم""لللاعة"" عنانانا 11لا اناك كك تاضدك ٠.‏ إم كم 2 تا 1اتا 


م لأطلاط تام ناك 5م اتات 1 انا 
""لاللاعط"" نان 11لا | كت تتاتك 1ت . لكجمع غخصم لاذلاع | 1 قاقضتق”م 8مك دم ططم اتات 1 اتا 
""لللاعا"" عانانانا81الا ا ”“كج”, اتات قط , تكمع غصم لأذلاع | 1 تطاقضظ” 5مك د55 ناكم اتات 1 انا 

هت أذلاص تام ناك عاطم اتا 1 ائنا 

لاءة + ]ا قطنا 18م لابانالنانا لانانا | خامات 5212 ط1اعع 1 25 اتات 1 انا 
2 ما دخايصغ عع | بعص طلال | عع عناع 31 دع 5 إمظشم اتات زات 
تاك تنا تاثا لضم اتا 1 انا 


7- الآن نريد حفظ التغييرات التي قمنا بها إلي الملف التنفيذي .. فنقوم 
بتحديد الاسطر التي قمنا بكتابتها بدءا من العنوان [01008/747] إلي العنوان 
[01008768] .. ثم نضغط كليك يمين ومن القائمة المنسدلة نختار أل ثم 
اخر اختيار [|00180ع»“<2 10 لإم0 ] 


كتمع طعازب ازع 
معنلا طعازثسب اازع 


أت عأععاعد 





عأطةلاععيزع دغ ممت ؟ 


وستظهر النافذة التالية : 
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التنقيح وأدوات مساعدة 


3 نذالحالكا .. . أوتزكة 0010/5 لللاتع عائع] - عع للدمعتمم - وطامبراا0 
2 ماعط كسضدلمائتذ كمصدلئمت ععةت1 ولبطعن سبعك عاع إظ] 


لمك زسلسء له الك ناوا :* انك الااء اع ع |وه زه 


كت رك سكددحنا منريكت بعل | جعدعمحروددم 

د #لاء ل 1لاع ] : ]اح رماع 115 لاك طخط” ررمت 
غا,[#“تع]: 2 ع[اماع لالانا ناكم كتمهم ض4قع”, انمتا 

تاع 111 كك 4ع" تعتمت 

الام ناكل نعل نوبرع ] : 2 ع[ا“اع نالا اك نكمتم مقط عنتمت 
اس ل لهاع ] 5 2 ع[ال“اع لالانا ع4عط”, صتمت 

الام ل تلع ] : © ع[الاح لالانا 1طعح” تاتاتاتا 

تم لاإئلام ناكم با تطح" نتمم 

جم عقت 1 ولام 1 تم" 8ك دم ططعط” متم 

كث 3قم8 1 لاذلام 1 تضم 5ك دم فرطط", عنتمت 

م لاذلا قاط برك عاطعط”, متم 

لضت 1 تطت 1 ]| :دنا 118 لاتالالانا لانانا | 1تطتطاتح 51 طزرعع 51ح" تاتاتاتا 

ليث كخعممتم دلال ععع اداع 21 داع « خط تنمت 

اعم لث ع ] :دنا كاج عامماع نالا امإف كله اصع ”, مامتا 


ييه 
المعوبادص] د عاناقدنر تلقمم أت أضاممح بارع 


قم بالضغط بزر الفارة الأيمن عليها .. وستظهر قائمة اختر منها الأمرع/ا53 





2 منكاءت 
ع الع 
دمت ...#أطالمعدوم 


عا ععدد 
ع أمأدصادعم8 
ع ععتما ا 





وقفر بخفقط تسكة إخرع مين العلف التتفيدف» باسفر اخر .. 


48- قم بفتح النسخة التي قمت بحفظها ببرنامج 019 وقم بإعادة 
الخطوة رقم ( 16) .. وتغيير نقطة بداية البرنامج إلي عنوان الكود المحقون 
[87/53] تم قم بتحديد السطر .. والضغط بزر الفارة الأيمن واختر نفس الأمر 
السابق [»©6006361©“ا5 10 لإم0»].. واحفظ الملف باستبداله بالنسخة التي 
قمت بحفظها مؤخرا.. ثم قم بتشغيل الملف التنفيذي .. وستجده يخرج 
الرسالة النصية "10|ا©6" تم يقفز لتنفيذ كود البرنامج الأصلي. أو تستطيع 
تغيير نقطة بداية البرنامج بواسطة البرنامج التالياع:0امعا تانان). 
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7 


يعتبر من الأدوات المتميزة حاليا .. والتي تحتوي علي أكثر من برنامج في آن 
واحد وهو ما يتميز به هذا البرنامج .. وتستطيع الحصول عليه من الموقع 


الرسمي : 





010». ع0ع]ا. /ا/الا/الاا/ / : مغخاما 


والبرنامج عبارة عن مستكشف كامل للبنية التنفيذية للملفات .. كما يتيح لك 
التعديل والتغيير بكل سهولة. 


بعد تنزيله وتشغيله ستجد الواجهة الرئيسية كالأتي : 


اك اك االا ععرمامعع عع 
كوصعععد عازع 


3 م 





بسحبه وإفلاته في البرنامج. - 


وسيقوم البرنامج بعرض البنية التنفيذية للملف بشكل رائع ومنظم. 
حيث توجد نافذة شجرة 116 علي يسار البرنامج بها بنية الملف .. تختار 


البنية التي تريد استعرضها .. وستجد قائمة علي اليمين تشمل جميع عناصر 
المنية بالاستماء والاراحات والاججامر والقيور الخالية والفعدي:فى تعض الاختات: 


24 


13 اتنا > إلنا 31 ارا 
م كوصلاعد عاع 


ميدع اندوع ]سد 2 


عرادا! 


مزع ممع مم21 تلع عبج اكبا اص طلا[ ابح | عندع لممعامم :عات ل دك 


جت عاطةعرععيدع عاددعممم علدع لا دهن] لقا 
عرعلدع ل إلا لقا 


علاع 1امب مسب إقردال!ا تأمعصد لم دلدء لا عاد لها 


كعبط 59110 8 ذاك. مك أذ عا علدت لا ادصدزام لا لقا 3ا 
تععطئط 59120) 8م لاكمق 1 ٍ [«] عع داععرزنا دادن لقا 

1 1 [] وعلوع لا مدوزاعع 5 لقا 
7 باإصاحع انا أندممما هكح 
بإإصاعع انا عع ادوع 8 نا 
مداعأة ممعم أمخم داك" عات "لظم ات بإإماععانا وباطعنا حا 


لقمعغدل"! مماعاماعععجاعااع اماع مما ممع للم 2 


عاادبا برعمع لمعمع رن بال 
(0408103-2158 مط تمع_ مودعم 2610010.21510, 5.1 ممتعرع ادع الا 3 
تماتلع برعلا 5ن 


تمع ادل" ةلاقم ععنان] | معلا 2 


رااتم! 


مع ممعم قغطواء أأت , مداعة ممعم عأمعمند كم أ | تعللث أتسموررا 5ن 
| 1 ا تعاطسعععدة 0 عاعزن 9 با 


زعغاء.لتمعأامم] - االا وعرمامع»ط 0ن 
كوماععمد عاع 
مزع دومع ]مو حلي" 
1 ' 5م 
“ يعمزموع | طرق بعطترع 1 
وعم 000 عبدع _لممعامم :مازع [] جح 
معوممممه | ممادعع نايع امناءمزةام 18306١‏ 005 لق 
ج]علوع ل ألا 3 
نان مماكعع بت رع ممصا" بعليعع لا ع 93 
زانا78لالانانا انانارارازانا عله ]نع 52 أعلقع لا أقضصدزام لا لقا 3 
00006600 010 ]| وءئة ملع دناة م1 مع 2د [«] عع ماعع أن ماه 0 لكا 


00000 04 أ 5ه ملع 2 زاةاغزم املا مع 512 [8] 15علمء ا مدتادء5 لق 


بوماععزن أردممم | ا 
أمزع, 391” ناذالا 6010| عمنمم ممع وددع للم بووام 0116 مع مع 8 ع 


01010 1 نان 0 نان 00 ]نعووة8 لبرماعع 0 وباطء 0 0 
000090010 00000110 قئة ن] أنمعوة8 تزع امهنا ععع للم 4 
010000 00000114 1101 تع عاد ببا برعمع لمعم 0 بإ 
2 "مالع برع 1 ب 

انان 1لانانانا 18 1الانانانا امع لمصوتاضممععع5 , 
ا ع1 ]1 أمعل | + 

01 002انانانا 0011انانانا امع ممموتاضعاك عللم أرممو| ب 


اضف _-- : 2 و تعاطوعععةة1 2 عاء ان لا به 
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التنقيح وأدوات مساعدة الفصلء 1 
- أدوات آخري 


يوجد أدوات أخري متميزة يمكنك استكشافها مثل : 


1 - أداة مزعم 
الموقع الرسمي : أأ.كقط.لاعم//:مناحا 


عالت 05 زعم 876 


عباع , نإفعع نلك نان نالة ]اتا عاص 


انزع | المصااصعك نع 21ت" لانانانا ١‏ ماحم لمع 


تق نام رفظ | كع انز اذا نكم قوضمم 'عععتات عازع 


آلاك تتتم تتا | تمععك كنات 1 | 'صام][ معنامنا 


زوناطعنا] #لمطععلم نم علا إقردل"؟ أ أمخصن ناكم 


ظ جاع ظ كاتأ نرت ظ عع ا عادة 1 ظ مقعد أعاللل؟] 
| _- د ا مدع مم قات | 





2 - أداة عمل:,:ها 
موقع التحميل : 01111030 _ عمل011/0».مموع]ق نلاعع ]1// :مخاحا 


الك رن |[ لعا ا ]| 


| مالكل ع عم ععاكدعوهلوا معد تاعوههما بزاع طادع 


50-65 11 111 1111 [معتعبرع] كج 
| #اوع امم 11 [ممعتعبرع] كج 


كك 0 تاماه 1111 
| عمس لاشطعة _ ممنع دده 435800 4 كن ن ونان عبطت عمومه مره اهبيع اد اواك اعم اق 
ااأمعصلا لالالاكلانانانا لالالاناقطرخك لاتاتانانالالانا عع ممعم كت روم ام بع كع باد لك وا ا اا 2 

92-3 


ِ عصداملا عداكعوقهما عد لاعودهما 


ٍ ألاتطرم 
ٍ اع 
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الفغصك 1 التنقيح وأدوات مساعدة 





3 - برنامج م0:!5110لالا »اه 


الموقع الرسمي : نوع . م0 جاى» !0 نانالاع جا . لانالانا نالا //:مخاحا 
برنامج لا غني عنه لاستعراض وتحرير الملفات وستحتاج إليه بصورة شبه 


[عغاء.لجمع201 ] - ممرايهاره للا عاء لا 
ماعط ب#املمئث وامده1 كمماغصمة كادوزن غللع عاع 


89 5 مه | © 85 قه 13 || © 7 9 8 8 ذه )4 | قا هك وه 2 2 | 
8 © | 8 ,9 <ة ينا | ؤ ذه 85 | هم | 














عبرع .لقمع امنا 


[00000000<ا0] 0 ععىمم 
و0 اناه | و6[ ع الا0د 77 عبر8 معموزك 88611 


7# عطمرق8 لمعموزكمنا 8811 
ظ 2023117 غنصطاك لععمماك آاقّةا 


| ...ممع 4# | المع 88 | ...06 )يذ علفاعانا عفعيدؤة [ 1 


كع زط 169632 7 بإعنااةا 





4 - برنامج 1( ©006نا2©2! © “ا1 1153556111 210 108 


الموقع الرسمي : 10م 103 / لنام». لزه اع جا . لالالالالانا / / :مادا 


وهو البرنامج الذي تستخدمه جميع الشركات الأمنية في مكافحة الثغرات 
والفيروسات .. ومجموعة غير قليلة من شركات تطوير البرمجيات لأنظمة 
ويندوز ولينكس 4151/19 9و1131الا51 وغيرهم. 


51 1 












665 ووع وسماج 
4 وه :1 إن 









010011001155 
11 0100 


100611001110101 00 892 


الفصل الثانين 2 


بببة أطلى الشهيري 


1 م211 آم[ 





الفصام 2 
بنية الملف التنفيذي 01036 ©ا80أله0عاط 208016 عبارة عن بنية لملف ال 
لاع وال اانا وايضا ملف ال ع1 06[66]6 التي ينتجه المترجم اثناء تحويل 
الشفرة إلي /إ31أه. 


وهذه البنية عبارة عن هيكل مغلف لبيانات الملف التنفيذي والتي تتيح لنظام 
التشتفيل التعامل,فع هذا العلف...وتتفيذ الأوامر الموحودة رة: 


تتكون تلك البنية من 5 أقسام رئيسية موضحة كالآتي : 
1 - ترويسة الدوس ١16306)‏ 117 005] 
2 - توقيع الدوس طلاأ5 005] 
3 - ترويسة الملف التنفيذي 263061 عم 
4 - جدول أقسام الملف ©7361 56600 


5 - أقسام الملف التنفيذي. 


]3ع 117 005] 
ترويسة الدوس 
ملاأ5 005ا 
توقيع الدوس 
معل0جع06 عم 
ترويسة الملف التنفيذي 


1201 56000 
حدول اقسام الملف التنفيذي 
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© أولا : تروسة الدوس:»306ه!! ١12‏ 5م56 


وهذه الترويسة خاصة بملفات الدوس التنفيذية ولها بنية باسم 
8عممعلا_205_ع1186 .. ويوجد تعريفها بالملف '©00010/5.10/الا" كالتالي : 


ا ا 8 1 الانلك _ منان 1‏ لم1 


5 كلمل 1ع ا 

8 كال قلظة دع 2 

2 «قكل ل قرم ك5 3 

2 1548© ا قباعدة 6 4 

5 لاا كت 5 

8 8148 1166م 6 

2 848 ا 6511-66 6 71 

2 81548 تسد 8 

3 كلمل مع 9 

8 8158 بالرتعت 1 

8 كالمل 8ه 1 

8 5ه 58 ع 12 

2 81548 ا 6 11 ع 13 

2 1548© ا 06 6 14 

(2 ) مرتدكهك 4 مانالا 6268 10 
2 60 د 16 

2 كلما 0630156 ه 17 

(2) تدك 10 لكلا 5٠-2‏ 1 
2 انا .ع 19 


5 2*0 "اأطل[اشظ05_11آ1_ط اش" 1 


عدد عناصر تلك البنية هو 19 عضو .. كل عضو قيمته 2 بايت 0]0/لا ما عدا 
العضو الأخير قيمته 4 بايت 010//ا0.. وبحساب حجم المصفوفات فيكون بذلك 
حجم البنية 64 بايت .. وتكون في الذاكرة علي هذا الشكل : 





| 1 0 0 | 
ط]'! . 1. . ! ........ 658 54 21 1[ )4 1لا 88 21 01 9لا 84 الا طلا شط 18 ططنا (ا4لالالالالال 


5220© 231605111 15 58 طلط ظ65 1ط 53 ا ([5 1ط 72 مط ط65 2/” 0 لات 73 59 لا5لالانالالال 
5 15 لبناعد عط غ 20 53 48 44 20 طط5ط 69 2 ظ6 كم 72 لان 55 2ط 20 74 لا 5لانانانالال 
سد بح لع حص حجد )١١١ !١]١ )١]١ 1(١][ 1١]1(‏ )ا ]١)١‏ آمم )]١‏ ١1ا‏ 0 [ن” امس بم بام 1 ا 1١١ ١)١‏ 


وسنستخدم من هذه اللحظة قيمر |ا306613<©! للتعبير عن الإزاحات 
والارقام. ءِ 

وفيما يلي استعراض لعناصر تلك البنية .. مع العلم ان عناصر هذه البنية لا 
تهعمنا إطلاقا في تطبيقات 81 32 سوي في عنصرين فقط .. العنصر الاول 
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الفصام 2 





20301 _» والعنصر الأخير /(ا306)|_»© .. ويمكن حذف معظم تلك العناصر من 
الحلف التسدى: ويستعمل البرباقة تدقن عتتناك : ” 


1) ©121301_© : [00-01] يحتوي علي الرقم السحري 40056[5] .. 
ويطلق الرقم السحري علي أي قيمة ثابتة تعرف صيغة الملف .. 
وهو يقابل حرفي الأسكي " 1172" نسبة إلي أا5/خام>ازط2 >3 
مصمم صيغة الملفات التنفيذية للدوس 005ا 15. 


2) ماطع_» : [02-03] صيغة ملف الدوس التنفيذية مكونة من صفحات 
كل صفحة بحجم 2 بايت .. وهذا العنصر يحتوي علي عدد 
البايتات في اخر صفحة في ملف الدوس. 


3) ©»_»© : [04-05] يحتوي علي عدد الصفحات في ملف الدوس 
التنفيذي .. وبهذا يمكن معرفة طول الملف هكذا : 
إذا كان ما©_»© يساوي صفر فيكون : 
5 م 2 يلج نومير 


وإذا كان ما0©_» لا يساوي الصفر فيكون 
2-0 ار التحواة مم 2 :نا وت 1 


والواحد المحذوف نتيجة لأخر صفحة والتي نحسبها منم|0©_© بعدد 
النائكات فى الصففة: الاكيرة: 


4) ©!”#©»_ه : [/06-07] ويحتوي علي عدد المدخلات المنتقلة في 
الذاكرة 063]1005ا©5 . 


5) 0311307©_»© : [08-09] يحتوي علي حجم الترويسة )6306 في 


الفقرات. 


6) »والقستصر»ه : [04-08] عدد الفقرات الأدني المطلوبة لتشغيل 
الجر امك 


7 ©2133110:_ع : [06-00] عدد الفقرات الأقصي. 

8) 55_© : [05-0] : يحتوي علي القيمة الابتداثية للمكدس 513616 
أ1ع50017. 

9) مك_» : [10-11] يحتوي علي مؤشر الاستاك الابتدائي. 

0) 1717لا5©_© : [12-13] يحتوي علي القيمة المقارنة 7الاكاع16آ6. 
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11 ) م1_» : [14-15] يحتوي علي نقطة دخول البرنامجت ]05م لإتأمع 
وهي قيمة مؤشر التعليمة الابتدائية )م2011 6100ل 51 11. 


2) 5©_»ه : [16-17] يحتوي علي القيمة الابتدائية لبداية قطاع الكود. 


3) ©43:1ا_»ه : [18-19] يحتوي علي عنوان أول عنصر في المدخلات 
المنتقلة في الملف التنفيذي. 


14) 01/110_» : [18 -148] يحتوي علي القيمة صفر للبرامج الرئيسية. 


15) 5©]_»© : [22-23 ,20-21 ,15-15 ,10-©1] مصفوفة 5ل]م/الا 4 
محجوزة. 


6) 0©612110_»© : [24-25] يحتوي علي معرف ال الا0. 
17) 0©61111110_» : [26-27] معلومات ال الاع0. 
8) 52©,_» : [28-38] مصفوفة 1/0105 10 محجوزة. 


9) الاع23ة؟|ا_ه : [3-40] : قيمة 01/010 تحتوي علي عنوان بداية 
ترويسة ال2<5 للتطبيق 3201. 


012345678962811 | " | «ل | ([ | 0 | 8 | م | 9 |8 | 5|777 |4 8) 4 | 3 |2 |1 |0 



















51211 2316531511 15 لط كاد 
11 ناد معط 6 اك 53 4 44 





























5.6666066... .215026 الا ١‏ لآلا لا 
6.5 5. . 5:. أا. (. *. شم اث 5ك 2م 
1.5 5:.عا. 5 . كل. ج:. 1| شم ناث 5ك 1" 


2 .عا . طك 5281 . 16 . ج . زد ثم اث يك 2م 
00 لالا 000 لال 












































ون 0م 04 00 


وإذا أردت رؤية خريطة الذاكرة بشكل أكثر تفصيلا.. فقم بتشغيل/ا|١0‏ واضغط 
علي زرا .. أو اضغط من الكيبورد [/411+1] لعرض ال م13 /زم لاع .. 
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ماك وردنا 


تعتددعم عم 
عددنا 
نزحم 1 
535لا 

دصح 2 باد دعا 


> ا3وةط [آلاتا 


مضا عععة 


دمع عد مراع 


تاتامم ثاتاتام 
تانامض تا تاتاتا 
تاتاتات تا تاتات 
تاتاتات تاتاتام 
تاتات د تاتاتاك 
تاتات 1 تاتاتات 
تاتات 1 ثاتاتاتم 
تاتات 1 ثاتاتام 
اتات 1 تاتاتاتا 
تاتات 1 ثاتاتام 
تاقاص عام تاتاك 
خاتات تت 1 ثانا 


ع حزك تم 


تتا قاتات 1 تاك 
تتا تاتا تح نات 
تاتاتاتاك ت تماتا 
تتا تتا كت مات 
ثاتاتات اتات 
تاتا مات تاك مات 
ثاتات 1 تتام 
تاتاتات ندك نات 
تاتاتات ناك تاثا 
تاتاتاك ناك تاثا 
تاتاتات 1 ىتات 
خاتاتاتاد” اتا 











اضغط بزر الفارة الأيمن علي العنصر المحتوي علي:56306 52 واختر مانام 


0 


نالا 


وستظهر النافذة التالية 


ععع00400.. 00400000 عع زم مدرزع - منج | 8 | 


د معمنرحما +23 2-3ددعنا 2212م 

"" 2م" تج 21 امنب *ة دو ا 5_تلانا "م" 5111م قات تمتك ام 
.ك1 د5دع+مةعم_تالالا كت 2 تنا اتنا نما نما لك ناما 

3 +لنناعوود 2 _ذؤنانا : 

ٍ أ نناد ] عط_ذؤنانا 


0 ع2 5ع كتلا_ذذدانا 
.كأتككة داوع بردزا_دنانا 

ع8 

ا 


منربكت بعلم 


اانا ناتاك تاثا 
نات نانك نات 
تخا تناك ناما 
عات اناك نام 
1 نانافاك تاثا 
12 تاخاتاك تاثا 
14 اتناك قاط 
15 تاناناك تام 
12 اناك تا 
1 نانك مام 
11 تاتاتاك تام 


ت نمام 1 "ا تنانا 

55 ]| عط_ذنانا 

3 تاروع برع_ذؤدانا 
- تربك عا انا 010 


عم ]2 - 
اك | عتع دالا 
تدمع دعم 


للا 
55 
نذا 


زبلا 


دج أ د 


+ لما كل 


فاخت تافافضه < ] 00 


8 ح ذا1_ااغنا_ذنانا 
6 ع دعم1_1اعنا_ذنانا 
1 ]2 تمعبسرعة صط_ذذانا 


كاك ‏ عاقاك تام 
عاك نا ناتك ناا 
مك فافاحاك نماك 
لات نا خااتا ك مانا 
عاك نانك فاص 
فت ةا اناك نان 


قاتاتاتتاماهمه << ل 


5ك ناخاتا ك ناتا 
نات نانك ناص 
لات خاتاناك ناص 


8 
م 
ا 
4 
م 
م 
8 
8 
م 
ع 
م 
م 
5 
م 
م 
م 
م 
8 
8 
م 


ا 
لح 


ضناه - هعمو +ناعط_ذنانا 
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+ ثانيا : توقيع الدوس تاناغ5 005] 


ملف ال 5 يبدأ بترويسة لنظام الدوس .. ويليها بريمج صغير به تعليمات 
بسيطة ليعمل في نظام الدوس وهو 6للأ5 005]ا حجمه 128 بايت .. وظيفته 
إظهار رسالة الخطأ التالية: 

7700 005آ ثأ انار عط اضرق 320 وهم كلط 1 


مدعوم في بيئة الدوس .. فيظهر الرسالة ويتم له من البرنامج. 


لا 
4 00 


ا االعوم وده 5م 91 
0 11 21 -5 12 





010 ا 49 2 03 05 ا 04 01 40 اا الا 45 
| 04 ثانا 06 5لا 01 8لا 01 طلا 0 لاط 0 انا 00 ل 




















إذ| لمريكن هذا البريفخ الصفين ممحوو فكانت «سيعظهر رفنالة مثل : 


,6007103750 أوطافعالاء 06 اأتصاعاما مق 35 0ع01712معع١‏ أ0م 5 'عممومعاط' 
.ع1] طاعأاقط 06 0030م عاموعم0 


بالتالي إظهار رسالة الخطأ بعدم الدعم ستكون مفيدة هنا .. وكود هذا 
البريمج يكون شيء مثل التالي : 
5 52 612235612] برعت 1137 
طق رطة دملا 


1101 
ط40 ,رطة ه11 


ط21 خ1آاط1 
ما يفغلة. الكوذ هو تعرير غنوات تض الرسالة إلى العسجرلاة, 


ثم يتم استخدام الدالة رقم 9 وهي مسئولة عن طباعة النصوص .. ويتم 


وَضعها فى الفسجل:ذاة: 
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ثم يتم استدعاء المقاطعة 217 والتي تفحص قيمة 30 فإذا كانت 9 فتقوم 
بطباعة النص الموجود في العنوان*0 . 


ثم يتم استخدام الدالة رقم 401 وهي المسئولة عن غلق البرنامج .. ومن 
ثم استدعاء المقاطعة مرة أخري. 
© ثالثا : ترويسة الملف التنفيذىي:©30ه16] عم 


بعد أن حصلنا علي عنوان ال 663066 25 من ترويسة الدوس من القيمة 
/لا30]]|_» والتي تشير إلي عنوان ترويسة الملف التنفيذي. 


فبعد أن نذهب إلي هذا العنوان سنجد بيانات ترويسة الملف التنفيذي .. 
وهذه الترويسة لها ايضا بنية عالتألا160أ5 هي 782055253 _7117 12152617 تعريفها 
كالتالي : 


1 1532 ناض 111 _ ناوه ظ 1 


2 م11 0اثاما 51901131112 1 
> ]آلالالششط . نظا 2 لان اا ع20ع2ع 811 2 
<> :11532 لقنا :لضان 0 0211 111661 15685061 066365 3 


هل 1611152 _ 111 كات ه11 1 
وبها ثلاث عناصر هم : 
3) 5101136101 : وهو توقيع مكون من 4 بايت .. أول اثنان بايت بهما 


الحرفين [عم] والمقابلين في جدولك الأسكي للقيمة [45 50] 


بالفكند.. فاخو اننان بابت يكؤنو ذانها :ضفر أى أن التوقية كوت 
قيمته [001 00 ط45 50 ]. 


ط) “«عل3»ع1!ه11 : وهو بنية من نوع 84088 لا_ 1186_1118 ..سيلي 
تناولها في الصفحة القادمة. 


ع) 031163061ه61م0 : وهو بنية 805532ل_7101/41م0_ع 11186 
وسيلي تناولها بعد قليل. 


355 





بنية +11 5_]1115_!!18865 11186 حجمها 20 بايت .. وبها 7 عناصر أهمهم 
لدينا هو العنصر الثاني: 


1 81 اا نظ شك _ د51 . روم 1 


8 6158 عط 1 طح 113 1 
2 158ل 2015560215 1110 آلا 2 
7 011 اانا م320 5 5 © 11112103 3 
7 11021 »21557011351 ع12هط2 4 
8 011 آلاما 201557015 ©1105 لكا 5 
9 10121 +2ع©30ع2312ه 5125601061 6 
8 كلا م 0 7 


١-5‏ ]ناش ظ ‏ ظءا 1 2 واه اناب[ 





86580017 01239356 | | يط | ([ | 3 || )| 9 || © اس | كا | 5 )ال || ١3‏ )| 2 | 1 |00 
5 .كآ. لك 81ج . غآ . ع . [خزطد شم نأش يك 2م 58 53 59 2ذ ثم اث 8ك 3 ثم شث 1ك 35 لا شنا نا نالا نالا 
.٠....6.6.........‏ )0 لا 00 ثانا 00 ثانا 00 تالا 00 الا 00 ثانا 00 ثانا 00 انا 10 08 نا نا نا نالا 










لاذلا 04 لاذلا 06 5لا 01 88لا 
ناذا )1 لانا 0 ثانا 10 الا 00 ثانا اا ثانا ا ثانا 08 انا انالا نا نالا نالا 


1 - 1131111 : قيمة 0:0/الا يخزن بها نوع المعالج الذي يعمل عليه البرنامج 
.. ومن الممكن ياخذ قيم عديدة منها: 


م014 باوع 148011_1386/ا_عالآع_عثلم الا 
0 لالع 4801010_1664/ا_ع الآع_عثلم “!1 
0 ألالء 140110_1112516ا_ع الع_ع6لم “1 


2 - 5قه81ءع055:عطنزيالة : قيمة 0:0/لا يخزن بها عدد الأقسام الموجودة 
بالبرنامج وسيلي توضيح الاقسام فيما بعد. 


3 - 111123165131110 : الوقت والتاريخ الذي قام فيهم المربط ااانا 
بإنشاء الملف. 


105/111201131١1 - 4‏ «ع2111 : وهو مؤشر إلي جدول الرموز .. ويستخدم 
هذا الجدول في التنقيح 0أ0©01001990(! .. وهو عبارة عن خريطة لتعليمات 
وسطرر البرنامج والمتغيرات والإجراءات والأقسام الموجودة به حيث 

يحتوي علي بنية 011) للملف تشبه بنية ]م ..ومن الممكن أن يتضمن 
هذا 0 ال لاع أو في ملف منفصل .. وإذا لم يكن هناك جدولك 
.. فتلك القيمة ستكون صفر. 


وافتراضيا لا يتم إنشاء هذا الجدول إلا إذا طلبت من المترجم إنشاء 
نسخة 6ع( من البرنامج. 
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5 - 1112015ل015[9: 1112ل : عدد الرموز في ال |60 7الاد ©1301 . 


6 - “ع301ع110113111م0 512010 : حجم البنية )©1630 |00]1003 بالبايت. 


7 - 15 613:35 : تحدد خصائص البرنامج في قناع ثنائي .. وتأخذ عدة 
قيم منها . 
٠ه‏ [00026] 118665_ع اقم 1 نا0علاع_ع11ع_ع11186 : الملف 
٠ه‏ [10008] الاع1ولا5_غا[ع_ع1:1866 : الملف ملف نظام. 
ه [20006]ااه_غاة[ع_ع1:166 : الملف اا .. لا يتم 


تشغيله بصورة مباشرة. 


8 بنية 81_!48858832ا15_051101 11186 حجمها 224 بايت .. وعدد 
عناصرها 31 عنصر.. يأخذ العنصر الأخير بمفرده128 بايت. 


ا ل نات ا ا لا لات اكات اا اا 
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8 «قكلم ل 11360:1 ذا 
8 اك ١‏ | 217251 ع21 0211 1133 2 
5 210000 27251 ع212 111201211 3 
2 لاما 51276010600 *4 
5 011 الاما 517601121131132 5 
8 0110 الاما 33> 311 512760117211111 6 
0 0110 الاما 501222720121 2010125 725 
8 0110 الاما 010600 835 8 
5 011 الاما 0013 235 9 
0 0110 الاما 111396835 58 
5 0110 الاما 20121211 لمشضطه 56661 ا 
0 0110 الاما 1021121 1شع 5811 1-2 
' ماكلا 251 ©2117ع 6 2351206057375 ©م020 113 1 
1 ماكلا 251 ©20117ع 6 231511206057375 ©م120 111120 14 
0 هكلم مه 251 1123017 012 1133 1 
8 كلمل مه 1 1130:1725 201 111 16 
2 ماكلا 2516 ع17اماء غ 75 0251155 1133 1 
0 ماكلا 2516 ع7ااء غ 75 111201251155 18 
ٍ 0110 الاما 02173111 251ع1232577 1 آلآ 1 
3 0110 الاما ©> 5176011236 20 
3 0110 الاما 517601115 21 
8 011 آلاما 00 0116 22 
8 هكلم 10 75 5 11 5 2 
58 «قكلم ل 1122022©212-5آ 24 
2 011 انا 277 ع 5 5127601513015 25 





8 021 لاما 10010111 © 3 256015 51 26 
2 011 لاما ©2577 ع 5 ع1م3 11 201 51 27 
و 021 لاما 3200010111 11 201 51 26 
2 011 لاما 5 22 ©30ه10آ 29 
7 011 لاما 15 05ت 3 57 1 20 0ن آلا لات 
كنظ 1ن امنا لمم 07 226 131311 31 


( :0112 2111115 1011201013 01851101 ام م" 


8 11 15:1 ماضاذن 1 2*1 وتميف 1 





م89 01234567 " بر [ | © | 8 اش | 9 | / 5 5 1 5 1 
..٠....6.6..6.6.......‏ 0ل لانا 00 لا 00 ثانا 00 الا 00 الا 00 ذال 1 نالا (ا8لانانلالالا 
ل .....آ..ا[ظ ا تالا ا ذا 49 2 03 5) الا 4 01 0 























١ 
| 
| 
١ 
١ 
١ 
| 
| 
4 655 /4 )0)0 )00 00 
4 ثانا 04 انا 00 نالا‎ 00 


وفيما يلي ما يهمنا معرفته في تلك البنية من عناصر : 


1 - 143916 : توقيع لنوع ترويسة الملف ويأخذ أي من القيم التالية : 
030 ع801اناععغاء )أط- 0108-32 
030 عا30اناععغاء غأط-02081-64 


2 - 5126046006 : حجم الكود في جميع الأقسام في البرنامج. 

3 - »512601111113112 : حجم قسم البيانات المهيأة في البرنامج. 

4 - 23غخ022»ع1113112نأولا )51260 : حجم قسم البيانات الغير مهيأة. 

5 - 2001655011111139/8011116 : هذا العنصر يحمل عنوان نقطة دخولك 
البرنامج أو عنوان بداية تنفيذ كود البرنامج .. هذا العنوان يكون عنوان 


نسبي 86/3006 لعنوان أول تعليمة في البرنامج .. فمثلا في المثال 
الحالي عنوان أول تعليمة هو 10007 .. وهو عنوان نسبي 810/8 - 
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5 ا3لنزألا ع76(]أ3اع] .. وبالتالي للوصول لعنوان نقطة دخولك 
البرنامج في الذاكرة .. نحسب [عنوان البرنامج في الذاكرة + (1000] 
وبهذا نحصل علي عنوان نقطة دخول البرنامج. 


06 : عنوان نسبي لأول بايت في كود البرنامج عندما يتم 
تحميله في الذاكرة. 


23 :: عنوان نسبي لأول بايت في البيانات عندما يتم تحميلها 
في الذاكرة. 


56 : عنوان البرنامج في الذاكرة .. وهو دائما ما يكون العنوان 
المفضل [4000001] .. حيث سيقوم البرنامج بمحاولة تحميل الملف من 
بداية العنوات [4000008] إذا لم يكن هناك تطبيقات أخري قد حجزت 
مجالة هذ | العتوات: 


ععع 00400., 00000لملصمع زم صعدرع - سه || 
معمودنا د53 لد ددعلا مريكت بنعلا | للم 
م" جح [ك اعلا الات 1 -11[_5ا_عاتات1 طرق م""غل"” 11ناتم خا ا تتم تاك اام 
12-11600010166 1110066 - صمز طعكم ك1 اا . م 
- كود ] عمد +لاعرعطم بالا 4 . 
432006 ت ملرة ع5طعع+ دناعم ا 1 طناك ارح دك 
كه ع 3صاطة ] اأاصطنروكت اعزت رامع خا تخات اتام 
ه ع دكاإحطمية امعطم بم تخرك ضرم ممم 
قمخ - عرعةدكل!! قمما عملا نامع ) 5 د 
1_1 81ت أ عاتان 1 _ططاعن الاتاعمع د جتن نكر عزع نع ددرت انا 


11 خان"]_ 2ت فانانا_اعلان 1 رعنا ]1ا_كتاظ1!!1 <- عنعطمساات ا ودلنم 
5 مت ] دس عبازع عام اعرد ردلا 

تا كحزعلراعع عام ا اعنصم ا لم نام 

.1824 - 1210150 5 خاتاك تم تتام 

-4كتضت د ا 2 1151 لمم خافاك خرتض ناكام 

8 - - 1253055 1ه +1 5 لان ا رما ناكد مله 


ل 


اك 
انا 


اتات 1 تا نات 
ثانات 1 نات 
تاضافك نات 
تتا متك نات 
ثانات 1 اكات 
خافت م صمت 


11 


تاضك 1 < يت 
نات 1 


0 
انا 


3 5 رس الل 


وكل العناوين النسبية في البرنامج يضاف لها العنوان ‏ 103068356 . 
لمعرفة عناوينها في الذاكرة.. فمثلا عنوان بداية البرنامج سيكون: 


2017-00 مع 5501ع800+ 1113068356 


وعندما تذهب لغنواذ بداية البرنافة ستحة الصورة العالية: 
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الالال - عددالاع | سعد" 
نع ]ا مداع ا مسعدااععتا . 2ت اع لمعم 


ض بردرام 

نمع | دمدلات ] عد ا" هنا . عت | صمعع مايه . لال > لافنا 
لاع م اتات تك ] مدنا 8م لاتالالانا لانلنا 

دادع مدنا مكدمسضخصناع | م1 .2ت ] عتعضصه دع ميل امس | صعرط مصنا مكدمكمناع | م1 .كت | ععهضدص»ة . هلال > لانت 


2 ح نردمدط ع 1 11 لادلا 

تت 1 قضكقظض - حدحر اوت | 3 ] لا تت 1 كات , جع زمعرط عم اع مدنا 
االااا ع #معحدصمط مض لاإولاص 

طكذض د معمدالاعؤّة | ممع ل طم لاذلا 
الالال ع غ+دجملاط لمت تمك ] :ذلا 218 لاعتلان لرجرام 


طنة :د ] بندزاوت | 13 نا تططذطلا نامد مد 0 ووه | د ا لا تمعد بيع . لال > اانا 
م عتصناء ا بع مض لأادلاص 
ددعممدع + ] بع 2 اعلمعما 2س ممع ع ا برع نت | ممعم ياك . الال * لاننا 
عبرع نورام 
دع , تع رلك 
عاتا+ تامع ] فدد لع باتاناليانا م #ومع ارلا 
12 1 م #«برع خالانا 
82ت 1 ناك نات [بالالات علاال 

وعت لا 


حْ 

[+دعع ] مجه ررم تلان لرجرام 

مت 51 ا نالعطا. تت معد بيع . لال > لافنا 
#لاع م 41ت تك ] عذنا طلم باتانالانا لانلن 


[ +دعع ]مجه ره اعنلبانا لرجرام 
تناك 51 ا لاع عتا, تمعد بي , ال > م 
تناع _ 1ت رتك | درمز مزع عار اران تارتم 


-< 0121| 
| 
م51 ناععتا ., مط طعذئلا 


.1828-2 ع 0011 
| 
م51 ناععتا ., تلط طذلا 


9 - 11ع6©181011411011111ع56 
في الذاكرة . 
[10000] . 


[10001] بالعنوات [4020001] 
الأول يسع ل [10000] بايت.. وهو ما يسمح 


.. وال 


0 -171ع1011111امهء1 ا 


ياتا 
تانتاف تناع 
نافاناك نالا 
ناما ذخام د تانات 


يائيا 
مانا كه 1 عات 
تاثا 


كم 
نات ماد قم_ طتاعع 


ناما اماك قاطاع 
نائيا 
نات خاتاك نام ا 


الا ك5 
اتات 1 نات 1 
تضاف تاداع 

5_2 
اناما اماك الال ] 
نانك ناتك 
نام تمع 


لعاصصصت صعاع 
اسمن 


ع 
نات 
عع 
5 


جع 
لاك 


3 
عع 
ع 


م 
5 


عع 
عر 





نات 1 نك تاثا 
قات 1 نلك ناتا 
:اقات 1 فلك جاتنا 
1 11 خكنانا 
1خ 1 ناك نائيا 
1خ 1 نك نانا 
11 كنات 
11 1 فلك تتا 
انا 1 نالك تاثا 
تا 1 كنات 
دمض 1 فرك ضرم 
تخا 1 تلك ناض 


4ه 1 قجمم 
تك 1 رك ترص 
للخت 1 تناك 
طن 1 فلك خاتا 
ككنا 1 نك جاتنا 
لرطخم 1 ترك تتم 


: يستخدم هذا العنصر لتنسيق إزاحات الأقسام 

. وفي المثال الحالي يأخذ هذا العنصر قيمة افتراضية 
. ومعني ذلك أنه إذا كان القسم الأول عند العنوان[401000] 
ومخزن به [1001] بايت .. فلابد وأن يكون القسم التالي عند مضاعفات 


وهذا :فى تحالة إذا كان حدم القسمر 


[9001] بايت 


: يستخدم هذا العنصر لتنسيق إزاحات الأقسام في 


الملف .. وفي المثال الحالي يأخذ هذا العنصر قيمة افتراضية [20017] 
بايت .. ومعني أنه إذا كان القسم الأول عند الإزاحة [4000] .. ومخزن به 
[501] بايت .. فالقسم التالي لابد وأن يكون عند مضاعفات ‏ [2000] 


وسيكون عند الإزاحة [6008].. وال [1508] بايت المهملين أيضا غير 


مستخد مين. 


11 -011:11306ع512 : 
يكون من مضاعفات أداع610ل1أا4ل566]10. 


12 -0111©20615ع512 : حاصل جمع حجم ترويسات البرنامج ..ويستخدم 


الحجم المحجوز في الذاكرة للملف كليا 


أيضا كعنوان لبداية القسم الأول 566500 2156 في البرنامج. 


3 -/ه 231310166101 : 
101 ]6_1 | ذارا_غ 1/480 


وهذا العنصر عبارة عن مصفوفة لبنية 
.. عدد عناصر تلك المصفوفة يتحدد 


. ولا بد أن 


بواسطة 11155 لاع_/ا82101_01180101"الالاا_ع1114806 وعدد العناصر 


الافتراضي هو1]6 . 
1لا 10175 48_01 1 4را_ 148002 
ّ 1 0//اما 5د5ع31/600لناأ/ا 
2 ا 0/ال/انا 512 
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درالاع لاا 1 ن)ع ]4_1 1 4را_ع0م "!1 
كل بنية تحدد عنوان نسبي وحجم لبيانات عن الملف مثل عنوان جدوك 
العتافين المضدر: ‏ والمسكورد للملف ,, قوان مصعم هروك مضادر القلق ا 
الماك قال شونا م كنات عقير عدون 1لا من ان | نه لشدر ها عه شن نا 
المعروفات اليم ,, 


0 لالع 2 ]| اااع_لاا0 0ع 11را_عاىما»1 
1 لالع 7101| اااع_لاا0 1ع 11را_عاىما“!1 
2 لامع انا 5ط ظا_/اخا ! لااع_لاا0 0غ 11را_عاىما“!1 
3 لالع لا10 اطع )لاع_7اخا | لااع_لا6ا0 0ع 11را_عاىلما/!1 
4 لامع 1177لا 7_5 ! لااع_لاا0 0غ 11را_عاىلما“!1 
5 لالع 0 اع اع كق7/_8اخا ! لااع_لا6ا0 0غ 11را_عاما“!1 
6 لامع الالعنا_/اخ ١‏ لااعغ_لاا0 0غ 1را_عاىلما“!1 
7 لالع ا 7خ | لااع_لاا0 انع 1را_عاىما“»!1 
8 لامع 7002| لاااع_لاا0 0غ 11را_عاما“!1 
9 لالع كا!_ل/اخا ا لاع_لاا0 انغ 1را_عاىلما“!1 
0 لالع 0 0)_راث0ا_/اخ! لااعغ_لا6ا0 انغ 1را_عاىلما“!1 
1 لالع __مالاالا80_/اخا! لااع_لاا0 انغ 1را_عاىلما“!1 
2 لامع اا لاااع_لاا0 اع 1ا1را_عاىلما“!1 
3 لالع 101 _الشاعما_,7اخ! لااع_لاا0 انع 1را_عاىما“!1 
4 لالع 10ل _/اخا! لااع_لاا0 نغ 1را_عا0لما“!1 
0 لامع ماع /ااعد5عما 


مثلا في المثال الحالي عنوان جدول العناوين المستوردة هو[ 20441 ]. 


ععع00400000..00400معع زمء عقورع - مدمنه [8] 
5 ممصا د53 23ددعلا ميك معلا | > ع رتوم 
2 ع ل ] قلا وض ا : دحزعاباع تم رز اا ٠‏ ||| اتا 1 تاساك ناي 
ثان كات 2 11532 آلا 12 5ك - ات 1 1 تاناكنما 
.182-24 - ع1 1لا122 35 
_ عخضك << نباك بادد ا 5 
آلا ااانا 1 لا_ازع ع تططلاكئ_عتاص1 1 دع ومع ؤم وعطابة 
مض جح 12 158 عع + ع3 انا انا 
طت 14 -_عنالاعة دصل عاحد 5 +زاع ح 1 د 
4236 2 5 "اذامنا اده 5 +لاع 2 ] 5 . 
.قط خض 1 << مبدرععوع امدعل #لامح | 5 . 00 
00 5 - غ1افمدنامدع لا +زاء د ] 5 - اأأاات 1اترضمومم 
- _دكوة ] عامرع قت | ٠‏ أت 1[ عضدامم 
.5 2 ع ع 5ل ناد بع نامرع طامر بك ما إجت 1[ تمك مم 
مه ع اي حومد عاطة | +عتمبع .مر إتت 1[ رفصم 
8 ]|ة شاطةه|ا ع#عدمنع - 1ت 1تضممضممم 
مم -< - 500225 عاحة | #خصصنم ل - |اتاك 1[ تاضجمتم 
ات قاطةا #نصحمن ل - ]4ك [تضكمتم 
اتاتاك < 002552 عاطمة ]| كدخ ددعم ٠‏ 4-210 1 ناتك نات 
. تاذاطا حت هداهة عغاطد ا عععربدعمعم - [أأاناك 1 تضكمتم 
هم ح 5001155 عاطة ا لنت] ع#معدنع - أاطط 1 تاقضجممتم 
ه ع عداد عغاطد !ا وصدا عمعمنع - ]كك 1تعضكقمتم 
عذع :101 دم ]ع ع6غ كت +إزعمرعنا ٠‏ ]21ص 1 تمرك نامر 
ح عداة قصاطة | عذدوع ] ل#إأعمعنا ٠‏ [أنا 1 تاضصجنمتم 
3022 غاطة | مدا #خعد ا عع ٠‏ أأائات 1 تاناك نايا 
38 - 1328 لمعا ا 0 قد نات 1 52 ٠‏ | إلجت 1 تاتاك نتم 
ل نادم ادشرم 1811| م ات ك1 1 ١!‏ | الا اتات اكت اتا 5 زس يك يا | ع اد" ا س| 





نضيف إليه [4000001] لنحصل علي عنوان الجدول [4020448]. 
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نقوم بالذهاب إلي نافذة 72الا0ا “«©1! الرئيسية ..ونضغط بزر الفارة الأيمن 
ونختار من القائمة المنسدلة 5100ععما <2- 10 060 .. او نضغط من لوحة 
المفاتيح علي الزرين [03)+111)].. ونكتب العنوان ونضغط»ا0. 


لقتو اام ما مماعكعر جع رعامع 





وسنذهب إلي عنوان جدول العناوين المستوردة .. ومنها نلاحظ مجموعة 
الدوال 5دع1206])«ا2 و13016 6617001011 وغيرها. 


ع حزك تم 
كك نات نماك انتما 


ناع+ 3 حدرع ‏ | *!! . , نرج | ل 
لط دام جرع د | 8# , . 
ام ممع عا . . لبمسح 3 ا 
1512-3 لاع . .1 31 .32ت 
لاتمع . 3 ترمجى روطع بردع 
*31]لاغ*عتا. ٠.ودا‏ 5 ١‏ 
اع 51 لاعأعح . "3 .ممع 
55-8 55 ]نا , برع برع | 
1312-2 نأك معدن " , نربرت 
تمعد * , درعود دم ام 
عع+ع85 ل . . لرعود ده 
.تحت ة با . . ة بحت 
دنا مكدفضكحناع 1 دلا أامء 
2ت | عتدردت . . 5 | معرعم 





ذا ذا ذا نذا ذا ايا اذا اذا الوا 1 الىذ1 عر مر ير عر ير ير ير يزيز يزرير مر نيرشرط 
51ل ل را ا 1 1 ل :1 ١1‏ [1] 11 تر عرز زر هال [ ا 1 ل را ا 1 ا ل ١:‏ ا 1 


ذا نذا نذا اذا لوا لوا اذا ذا لوا لوا اذا ذا ذا ذا ذا ذا ذا ذا ذا الوا لوا اذا اذا لكا ا 
ذا ذا لذلا نذا لكا لوا لوا ذا اذا لوا لوا اذا ذا نذا لذأ لكا لوا وذ لوا اذا الوا اويا اذا ذا ذا ا 
0 
ذا ذا ذا ذا لوا ذا اذا ذا ذا لوا اذا ذا لذلا ذا لكا لوكا لوكا لوا لوكا الوا الوا ذا ذا لكا ا 
لذ زذ] زذ] جذ] زد زذز زذز تدز زدز يذز يذز زذز زذز زذز زذ] زد زد زذز تدز زدز يذز يذز زذز يذ يداد 
“للا ا كا نااك كان كاك شان كا لقان اكاك كاه كان كان شان كاك كن كان أقاكا كن أكاكن كاك شاك الك سيق 


كلا من جدول العناوين المصدرة والمستوردة لهما بنية تخزن بها معلومات 
المكتبة والدوال وبيانات اخري .. وسنتطرق لكلا الجدولين بشي من التفصيل 
في فصلي الحقن الثابت والديناميكي. 
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رايعا : حدول أقسام الملف ه1١13‏ 5661100 
جدول أقسام الملف عبارة عن مصفوفة لبنية بها ترويسة الأقسام 56600 


!ع1»30 .. عدد حدود هذه المصفوفة يتم تحديده بواسطة العنصر 
275 الموجود ببنية 1541018_ع11_ع0م!1. 


البنية التي تحمل ترويسة القسم هي : 


811 كراش كاك 1ن 1 1ن ك5 : ٠‏ كرت هل 


(2) 115ك ف 510053 لظ 1 رن 1 مله 31م 1 
1115 11212 
2 0 3 1 5 7تطط 2 
52 04 ©>7 1712113151 3 
605 
52 0 5 171213-02 4 
2 040 132 7 51 5 
2 0 201226232 6 
2 00 0022165 1 ع2108 0126م 7 
2 040 210112211165 ©13126همط 8 
2 7ه 5 002131 1 201226 11115 9 
2 ته 20151-12217115 11116 10 
2 0 0022222221515 11 


0 الاش ط11 _11 580110 _طا شا" 1 122 


والعناصر المهمة لنا بتلك البنية كالتالي : 


1 - 113:11 : يحمل اسم القسم بطول يتحدد بواسطة 
ع"ادال_50081_عمع512_ع10146 والطول الافتراضي هوة بايت.. 


واسم القسم يبدأ بعلامة النقطة (.) واسماء الأقسام تكون دالة علي 
محتواها مثل (أاع].),(03153.) 


2 - ع1431512 !ألا : يحمل الحجم الفعلي لبيانات القسم في الذاكرة .. فمتلا 
إذا كان حجم قسم الكود (اع].) هو (10005) بايت حسب ال 
أمعماصو[اخدهاءهء5 وتم وضع بيانات به بحجم (1001) بايت .. فسيكون ال 
ع31512لل/ا هنا قيمته ب (1001) بايت.. وهو الحجم الفعلي للكود. 


3 - 55ع14318001]!الا : عنوان نسبي لمكان بداية القكسم في الذاكرة. 


4 - 5120115311035 : يحمل حجم بيانات القكسم في الملف .. تبعا 
لمضاعفات أ0ع7اضو1ام ه11 ويطلق عليه 512 /لا83ا. 


03 





5 - 1014311033 1مع201:15 : يشير لعنوان الإزاحة لبداية القكسم في الملف 
ويطلق عليه أع015 /لا83]. 


6 - 1131361115115 : رايات تحدد خصائص القسم . 


القسم به بيانات مفياة والني 
سيتم تهيأتها بالقيم الحقيقة قبل --011_10/171411220_لاه5د_ع مم1 
أن يتم تشغيل الملف 
القتسم به بيانات غير مهيأة .. 


والتي سيتم تهيأتها ب واالالاا قبل راع 11/1114112اانا_1لاكت_للهك5_عهم !1 


أن يتم تشغيل الملف. 
القسم تنفيذي ©001301©“«] 
القسم للقراءة ©303601ع] 


القسم للكتابة 6اطةغ] ]اا 


وكل قسم له خصائص محددة .. فمثلا قسم الكود عادة يحمل هذه 
الخصائص [ع3031ع+عاطتهاأنامع<«ع +00 ]. 





مدع ممصا 
طارمرظ رهظ م"" برومع ."> 1-11ئم 
حِ . ./ لاعاتعطصصقضت انا 
عحدكت 2 ا دبع 1 ا اتات 1 تاتمم 
.4تض1 ح دع كناسدطط +زات 5 1 5 نات ىك حاتم تتام 
ضاضك - 85د لاسخحات انع امعط تام خضت لصم 
كه 5ع كورده] لاخصه ]| عات ازع رامع تام طخ نض ترم 
شاد تختع طن ستاك سا ات ] مع خدا دم اتا خاخ تم تتام 
0 - كرت ] كمعد لامع رعرع طم سم ع 
عا د ختعطم سناع ما ا #ناسعطم سلا ع 
لاقضعع اع لاتاعومع 0 - 5ت | داع حدمت انا اتات تت لاطت نالا 
"" تعغدك:2 . "" -ح 821 إعناددل" تارق ,""5 +دتس .*” 5111م 
4ك - 512 ] د باس اا نالا 1 تطتاضتات نالا 
تمصت اد 802-25 ] ه باع ] لا اتات اح العم 
.512 -ح 5غ تكناسدط +زاء. 2 51ت تام تخت تلم 
ضقت - 85د لاسكخنات ازع + وراد اتح حاتم تام . ا 
2 ع كرد ] لأكده | عات اخزك ‏ ماحد ات خات تا اتام - ادع 1 تاتاك نام 
- ديحتغطم سناكم ا اد اعنذك + ماحد خاتخاك تا تام - [إأاناع 1 تاتاك تام 
ه ع كومت] عدعد ]| مع الاعرصطنم بكم ع | اتات خاتاك كم 
ل دعصطم ملاع ما ا للاعرصطم بك ك] - | ا نات ناناك ناكم 
لالاع ؛ نم[ بارا 181-1280 11411 > 5ت عشت اعرع حدمت انا تاك قات قا اتيك نالا » م | ىتات اناك نات 
23 اعمد !]ا | رتك رظ ,""ت غدك .*” 11-اد5م . 
26 كبك 0 اتات تاتعاصضتت ‏ نالا 
عاتم ات خا نمم 
.2 - لبك 21ت 12 مات خحراض تم مر 
تاضناك - 5+ دناسكططاد | نك ماد عاتم رتم عترم 
ت كوت ] طأاخححده | عبطت اعرف + امع احاح كم تطلم م 
حت دكعنزعطم باع دا ات اعنع ماح نات خاخات تتام 
كدت ] #قعه | عع الاعتعطنم بك م 
دصغطض سساناع ما ا +لاعرصطم بم ع 
ع11تالنا ؛ لاضع نا ذدانا_لاعات 1 ات1 11111 د 5ص )| 2د امع مدعت انا تاك قاطت نالا 
9 ععروس ,"" دح لخ اعدداا | ضرت مرظ ,"ون دن" ا 
.كط 2ت مخ 1 ذا دباع 2 زلا اتات نح رات تتم كم 
تافضصك - 25ت كول | دبعم ا اا ات خاك تتام 
.خةض1 - دع دمناسدط #زات ح 1 5 اتات ك حاتم تلم مر 
تاضناك - 5ت لاسحنادت ا عرع ع وراد نالع احاتم ترم 
ته > كوت ] عقحت | قاطت ا عزف +ومامع اتات خاخات تتام - 
كه ع وحزعطم ساكعنا اد اعنع ممع اتا اكات ترام - | نات تاتياك ناكم 
8ه ع كورت] دهده ] مع الاعرصطنم بك ف - ااتططح ناتك متم 
ه ع وطعغطم سناع ما ا للاعرصطم مم ع طططه ‏ »ع |اختطحتصك متم 
11 ع 5ت دامع عمد زه انا فك تاتا نا تاتاك اك . خطات تا ناك ناكا 


لاناعط 1 نا انانا_لاعت 1 ام 
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# خامسا : أقسام الملف التنفيذى 

بعد ترويسة الملف التنفيذي ١16306:‏ 58 وترويسة الأقسام /ع630١‏ 000ع5 
يأتى البرتافة التتفيذفى نفسية ن., والمختوي على الشبهرة والبيانات.. 

ومن ضمن تلك الأقسام ..الأقسام القياسية التالية : 


1 - القسم 00©6» : 


جميع الكود الموجود ببرنامج يتم تجميعه تحت هذا القسم .. وعادة ما 
يكون باسم (أ“اع].) .. دلفي تقوم بتسميه هذا القسم(ع600.) 

حجم القسم محدد في الذاكرة عن طريق 6]اع 5660104110117 .. وإذا كان 
الحجم الفعلي للقسم أقل من القيمة الوهمية المحددة .. فيتم ملء 
باقي القسم بقيم صفرية حتي بداية القسم التالي. 


2 - القسم 0315 : 


جميع المتغيرات المصرح عنها صمن البرنامج .. يتم تجميعها تحت هذا 
القسم باسم (038.) .. بينما المتغيرات الداخلية 65ا3136// |0603| يتم 


تخزينها في الاستاك.. لين في هذا القسم. 
3 - القسم 03153: : 


ويتم تجميع البيانات والبنيات الثابتة في البرنامج تحت هذا القسم باسم 
(20313.) .. من أمثلة ذلك جدول الدوالك المستوردة 13616 غ01م17آ. 


4 - القسم ©:5: : 
يتم تجميع جميع المصادر تحت هذا القسم باسم ©65.) .. من أمثلة 
5 0 والنوافذ الحوارية والأيقونات. 


وتوحد أقسام أخري لا تهمنا في الوقت الحالي .. وإذا كان هناك قسم غير 
موجود .. فهذا يعني أنه يوحد قفسم أخر له خصائص 5غ0]6ا31]112 تنيب عن 


هذا القسم. 
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الفصل التثالاة 







- حححني الى‎ ٠ 
ال ا ل‎ 
7170277 1 

01001100115 


2100 1 - 
1110100110010 1 


0 


ْ 





ناب ا لشيل كود 


[0م0ن6عع01] عل0ن)] علمع 1 اعد متا 


كاية اليل كو 


يتكون الشيل كود من سلسلة تعليمات مكتوبة في صورة معينة بحيث يتاح 
حقن هذا الكود في تطبيق ما ليتم تنفيذ تلك التعليمات في وقت التشغيل. 


يعمل الشيل كود علي استغلال الملف المحقون به .. ويوحد نوعان من 
أساليب حقن الكود 00اء10(6 ©6006 : 


النوع الأول 583412 : ويحدث قبل تشغيل البرنامج .. أي أن التطبيق الأصلي 
يكون مرفق معه الكود المحقون .. عن طريق تعديل بنية الملفع5. 


النوع الناني ©131111ال1 : ويحدث بعد تشغيل التطبيق .. ويتم حقن الكود 
في ذاكرة البرنامج فتلا عن طريق. استغلال ثغرات فيض المخزن في تطبيق 
6115 /666لا8 .. أو حقن شفرة أو مكتبة اا0 في التطبيق. 


وأسلوب عمل شيل كود احترافي يكون كالتالي .. 
عنونة البايتات 8001155110 دع]/١ا8‏ 


تعتبر من الخطوات المهمة التي يقوم بها الشيل كود .. هي معرفة مكان 
وجود بايتات معينة في ذاكرة الملف .. مثل بايتات نص ما. 


فنستطيع معرفة عنوان تلك البايتات بحيلة بسيطة .. وهي عمل 7275[ لإجراء 
عنوان بداية تلك البايتات ومن ثم استدعاء ||3© للعودة.. وعند استدعاء ااقىء 
فيتم دفع عنوان العودة إلي المكدس..ونقوم نحن بسحبه بتعليمه 00م إلي 
مسجل لذينا. 


المثال التالي يوضح كيفية عنونة البايتات : 
[عاع60_1كل/ا 501 ملكاز 


:+1 داداظ_0)دكلا 
“0 م00 3 


خم لع 


اع56_7م 47 
؟ارارامظ_150 اادع 
"#علوع]اعط؟ ومتاملال" طل 6١‏ 


١ 


السطر 1 : يتم القفز إلي إلي عنوان الإجراء 1156_7277 والمحتوي علي 


رسالة نصية نريد استخدامها. 
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السطر 2 : عنوان إجراء معرفة عنوان الرسالة النصية. 
السطر 3 : يتم سحب عنوان الرسالة من المكدس وتخزينة بالمسجل»مه. 
السطر 4 : عنوان إجراء الرسالة. 


السطر 5 : يتم القفز إلي الإجراء 56_28" والفرق بين استخدام 
مازوااةق للقفز أن |63 تدفع عنوان العودة وهو عنوان السطرة6 إلي المكدس. 


السطر 6 : ويحتوي علي بداية بايتات الرسالة بطول معلوم وهو طول 
الرسالة. 


تحديد نهاية النصع0ز8 |انالا 


يستخدم البايت ٠‏ الالا دائما كرمز لنهاية النص .. ولكن إضافة بايت الالال 
للشيل كود قد يقتله ويسبب خطأ في تنفيذ البرنامج إذا كان حرف ال 1 انالا 
ضمن سلسلة تعليمات .. ومن الأثمن إضافته وقت التشغيل 1186 لاا عن 
طريق تحديد عنوان البايت الأخير في النص .. وتبديله بالحرف ل الالاا.. وهنا 
لديك الخيار في إضافته في أي مرحلة تبعا لما تحدده أنت. 


والمثال التالي يبين كيفية عمل ذلك : 


[عاع60_1ذل/ا 01 اد مار 
:+ادادطظ_50 لا 

“0 م00 

اهراج :0< 

ام [18 + <«مع] عالاط /املا 


حر رح زر) لح تلن 


:56_11“ 
“ارارام_1506! ااج6 
'#ع00)اع55 ومنلل" طل 


00 ل‎ ١ 


السطر 4 : نقوم بتصفير قيمة المسجل|3. 


السطر 5 : نقوم بنقل القيمة صفر إلي بايت عند العنوان [18+)06© ]وسيتم 
تغيير الحرف '#' بحرف الا الالا. 
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كاية الشيل كو 


تحميل المكتبات 1113115 102301110 


من الأمور الهامة في كتابة شيل كود دائما هو استخدام دوال مكتبات الريط 
الدياميكى. فلات ...ؤهدة النغطة ستسرة زها ضع صفحات لاتها اشاس 
الشفل كود.. 

وفي البداية فنلقي نظرة علي الكود التالي والذي يبين كيفية تحميل مكتبة 
راسكدعاء ذالة يها في رفت التشفل. 


1 3 

اأقعلطة زد اعددم, غ2 

2ن تكانتا 35 1أنالانزن 3ك 

ب 

عاكا , كبتبتصاع ما متختعاعبا| عصلك2تتتعدمم تع عددا دم 5ك 
عطل عت عصععهمل تععب اعصاكخعتمنعكضم تع عاءباعصا م 
دزا عت اعد هيل دازاكعتسسكخصل نع طأاع باعص م 

3 

5 035 

لا,'|ا عت عدبا طك تعدبا 11 

ناراك :مظطعوددمع ”ا حك نندت 11 

لا أعاممديةع #«منعود ددعلا حك حداامده 12 

13 

14 , 23 

ك5 15 

عت اعكنا #اناناك,؟؟ !]3 اطاأالققصا عغاصئتضا 15 

3ع لتأقنلاصطم 17 

اماك #الاناش ,نتتع ددع عفدم طاعدا ععادم كما 13 
“انا_ظضكا تاضباص 193 
ااداأموء [عطععن! (اذلام لات 
#مطاوكمر اعد تان دأقبام 21 
لا دأكلانم مت 
دك أأدء 23 
34ت لزنام كت 

تع ,1ت احا امع عوادملا كت 

لارععععص عط ابرع عوادسمز 5ت 

51311 نالذاا م2 
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كتابة الشيل كود 


السطر 16 : نقوم باستدعاء الدالة ١03011131‏ لتحميل المكتبة الممررة في 
عنوان النص '|032.0ع005". 


نأضا عالاقصصط عاطق أناععتنع لع الاععمة عط ممق تمتتعصل؟ لأارقتط | الهم ا عطا 
855 هدام تطاااقع عط أه ععدمة ددع 0ق عط 


الات تااالده ا الات 1 115لا 
أ عضلةقضع | أم كمع لله م عت الجا طا_اضرا 4] 1 15 :)0 | 
عاناكمصم عاناة ادع زع 1 


وعندما تنجح الدالة فتعود بمقبض الموديوك.. والذي نستخدمه مع دالة 
15 )2 .. والتي تقوم بمعرفة عنوان دالة داخل المكتبة. 


نع الأاععمة عط©ة أن عمعرللة عطا كضالائق؟ قملتعضلة ععع و أوايكن مور لامها عط ا 
تالا بلانا] نلق اطاا عاضاا-ه املقص ول لع 1رممنرعم 


أكدع ل لمكن ور شاع جا ]ا لاقع 
عالالصتة اانا ما عانقصوة م بعابامانالم ]ا الانا انا 
ما تالالا أه عاتلقم كم ك3 لالمدم رم 1114 05 | 


| 


الففامن الأذل تمروية ويه الفكفية :.. والهعامل الثاني ثهروارة توا نامر 
الدالة.. وفي حالتنا هنا الدالة هي [1165530680«8] .. وعندما تنجح الدالة 
فستعوة يقيمة عنوان الدالة ذاخل. المكسة: التى قمنا رتحميلها. 


ومن تم نقوم بدفع معاملات الدالة “1165530680 في الاستاك تم نستدعي 
عنوان الدالة !١1»5530680‏ في السطر 23.. لتقوم بإظهار الرسالة النصية. 


ومن المفيد استخدام دالة /19ة]طناعع:] لتحرير المكتبة المحملة من التطبيق 
الخال نبعة الانتهاء منها ين ودلك فون فقينض المؤد نول لقدة الذالة: 


وبالتالي إذا أردنا استخدام دالة 881 داخل الشيل كود بالطرق التقليدية .. 
يجب أن نستخدم الثلاث دوال التالية : 
0301151319 ا 
5 ماع00 
0 مع 30م م 
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كاي اليل كو 


كل دالة من الدوال السابقة لها 356 0لإتأمع في مكتبة ال اانا .. والصورة 
التالية من برنامج !3116//ا /ا170 6106©( .. تستطيع الحصول عليه من موقعه: 

مامك.اعغ اق /ظالاع مع 0 معمعل. /الانانانانا / / :مناحا 
يمكنك استخدام /ع0املا خا لنفس الفرض لكن البيانات التي نريدها 
متناتثرة به. 


لساك زاال.#تاعمعععا] - «ععلاد لاا بتعمعل دعمعنا 
ماعط جادلمتتك عالادئع كمملامت سبع ازع عانم جلها 


“نا 1 نا نا ناناءنا خازة زطاأالةصا 
ع 4ن 1 انا ناناكلا شوتع رق نطأالةصا 
1 عات 1 نالا ناناكزلا لبعز زطاالةصا 
8اعم نا نا نا نازلا لازت طانالةصا 
15ل اننا عاادا"الققصا 
5اق نا نا ناناءزنا عع نادو 31س ا 


ععاك ادرلطكذ؟ه | عددع لعمعاعمم | لاص | عدازك عاص | مامألا 
لا ناناك ]نا نا نائزنا | 01 لالانانا لام نا 355 | ختذرةة ان اعلاعع» | 0 
نالا ناكات لا نا نازلا لالانا نالا 19م نلا 55 | تكلارولام اعان.اات81 | 1 





كما لاحظنا .. قمنا بتحميل مكتبة 7©|132]ع»ا به.. وقام البرنامج بعرض جميع 
الدوال الموجودة بالمكتبة .. ومنها الدالة /19 0301163 .. ونلاحظ أن عنوان 
الدخول للدالة عند الاوفست [8//(آ1] .. نقوم بإضافة هذا العنوان علي 
عنوان ال 8356 10306 للمكتبة وهو [7/)8000001 ] 


780000011107770 -م/اخا+ع835ع1130 


إذن لاستخدام الدالة .. نستطيع استدعائها عبر العنوان ‏ [801107//8)/].. 
نفس الحال مع دالة 55ع0©1208001 سيكون عنوانها [ط0)80/220/] .. 


قالتالي [ذا أردنا تخويل الكوذ التعابق + الخاض تتخميل مكدة 2 ]| 


واستدعاء دالة “1165530680 وقت التشغيل - إلي شيل كود فسيكون 
كالتالي : 
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كتابة الشيل كود الفصلم 3 





: 1125012553121 1 عطاةه 1 
13521232 ط1215دصنات 31133 د 
:221111211 ت 3 12 2 تلا 3 
5232.011 5" ط دياع >2 > 013نم . 
312 1152 1ق دبا "1111م ,11ج 11012 5 
0117. 155232 تلع +27 1 1111511 م 
31 1112 طاعغة دا 1 251 17 للقت 1 
1331:3112 111112 دن 2122 2855112113 زجع ]| انلام - 
111 1 8# 522 5 5 112 1215 دنات 3113113 2 
لا1 
:18551121 داظ 535 55 1152 11 
"از دط مقت ت م1712  *‏ طاصجار 277 > تزوم نر 1 
لا > #تومة ع تا ء , مااع 1 وعد 1 
"لل :حاط 532 5ت 5 112 ”> 1711 ع >7 1 1111511 11 
1313:3112 1111112 دان 211311 م 37 2 211 نان 15 
11-3 الل حدم 2 2 با مجاعم الات اه لات ا" ,11ج 11106032 1 
تع عتدة 65522512222331 1 1 قا 1-7 
2-3 111ل صصص 2 اهما 2511 ع متت للقت 1 
1113 طلز دظ 552 5ت 1125 2ط 335 نا 75 [زتقع ]| تلام 1 
3353-2 112 15ج 1133 لات 
21 
:8552111211 52 55 112 5 
"5255 5 5 6ن" قطعط مئاع >7 > 013نم 23 
[] 5 يمرحمدعع تاج , عتااع توعد د 
خآنا_18 ااتباط عم >7[ 2 1111511 دك 
11518 21151 >7 1111511 داك 
1 25 203 112511ن1 ا 
للك اطع >7[ > 1111511 لات 
ّ«دط عونق 11255 1 51اء جتدع للهقت 0 
: 2ط لات 
-- دس اع هداع ام ءلات الل الك 1 123 ,3ت 11106012 31 
11-25 5311اع تدع للقت 5 
لت داح حال 5 
1321332-21 للقت 5 
لام '232.93117ه ت11 ' طلك 5 
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الفصل 3 كتابة الشيل كود 


: 11101 "71 صط داهة تت 112 5ت 


5-2-1211 553235 112 للفمهت 3 

لام الل * صط دعوة 171235 ١‏ حلك 55 

5 1112 55 5312 : 

522-12 5ت 11-2 للقه الى 

لام 115121١‏ 5112 111:35 15 2لا ١‏ طلك 1 


: 1113 12ت 1 1 112 م لد 


تم التعليق علي الأسطر مباشرة لسهولة الفهم .. والآن بحقن هذا الكود في 
أي تطبيق متل الآلة الحاسبة 031.76 سيكون الشيل كود الناتج بطول 99 
بايت كالتالي : 


اخاناناطة8 8 '456 فك 1ل١)‏ 8 | ذظا| لا|'ا| 8 اذ |9 |8 |/ |5 |5 | 4 إلذا)| 2ك |1 ]لا 


َّ 
: 
ل 
ل 
5 
0 


: 
ّ 
1 
0 
1 


الا 





طريقة حقن الكود برمجيا سنعرفها في الفصل القادم .. ولكن من الممكن أن 
تحقنه يدويا عبر لإاا0 بلصق الكود بيناري 63166 /810319. 


وقد قمنا بحقن الكود في لإ||0 عند العنوان [01015800] وبطول 99 بايت 


[63] أي إلي [01015862] وقمنا بتغيير ال +20197/20[0] للبرنامج لتصبح عند 
الاوفست [000128800] : 
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كتابة الشيل كود الفصام 3 


انل نمع ] :طنا زم عزلاع الام خاخاناتا 
لع 121 .ادح [نانالركت لال وح عاب 
باع عررم 6 
يةتطط|] _اتكصا . 32 اع مزع نا م ممع لارللا ل 1م عم 
تناع لإوئلام 1ع 
8ع االانا 3باعع 
2121-8 .ادح [نانالرت لال عت ععاب. 
لاع صررم كك 
لاع مثتلاع الات 2لا3ت 
تناع لاإدلام 51 
بأباع لاإدلام ناك 
2 لأإم دمن لعتا , عت | مومحم عا م تمع لارانا ناث تا عنرتاتح عع 
8ع االانا 3باعع 
لجع 81 1[ قمع ادح [ نانالرت لال 1 نعب. 
بتاع ررم 5 
لاع ملاع الات 2لا3ت 
لاع لادلام 2 
تناع لإزدلام 51 
تناع لازدلام 1ع 
لاع لاإدئلام ع 
لاع االانا تاباعع 
5ه جدنل أ اسع عت | م ومحرع عا , يبرع انلكا 21 ابرع دع 
لاع االانا تاباعع 
تناع 11ت ,رج ا دج االنا ععع ع ع عتن] دع | 
كمع 181 .ادح [ ثانالا لال 23 طثرد لم 
تقناع 8121 .مادج [ انالك عل 03 تروطت إت 
1 دع ] :ئلا لزع ع[ااع مانا الات عتددك 
لا ل1لاع]:دع طاخم عزامام 115 لات : كك 
لا [1لاع ]مدع طزمع ع اماق 115 نام 
عام_ان لالانا 2 عا اتا 
عحاعص [111 عع لاما 
اا عععع 
نانع ناعانا لاك 
م ممع 1821 , عا كدح [نالاامدك علال 3 روطم 
لأنعررح 51 
“لاع 111 تا قطة ثثرة 
ل اناع ]ا قدع نزخ لابطنالنانا ,“نا 5[ لانا عم 
نا باع 8121 .ادج [ الراك ذل 1+ خمرب. 
إعامان لانانا 2 اتات 
عع تك ازعم عععرع يرن 
[1+2لاع ]ا :تنا 18م نانالاليانا لانلانا خم مصعم 
“خط قغطقق , [ أضطح + عع ع + راع ] قطنا طلم ناتانالبانا م رطع الا1ا] تطقص درك عك وضكمروام 
لا [ل1لاع]:دع غاص عزاماع 115 لات :طم 
لا[ 1لا ]مدع طزع ع امام 115 نام 
خاي , ل خذضخ 1 ناع ] :نا 218 ناتانالنا اأعرنم دك عضدهة 
انال نمع ]:عج ةا بزع عزلاع الام اتات :طم 
انلمع ] :دنا زم ع[زن“اع لالاتم تاتامتم 


وعند تشغيل البرنامج تظهر الرسالة التالية .. ثم يتم إغلاق البرنامج. 





يمكننا أيضا كتابة الشيل كود السابق علي بالصورة التالية : 








ع2ع121ت 


لكا ذا نذا نذا اذا لوا لوا اذا نذا ذا ذا اذا ذا لذلا نذا لكا لوا لوا اذا ذا لوا لكا ذا ذا ذا نذا لكا لكا ذا اذا اذا ألا الوا اذا نذا نذا نذا لكا ذا لكا نذا لكا ادا كط 
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الفصك 3 كتابة الشيل كود 


: 11501255321 1 قطةه 1[ 
321235 للقت 3 
:125 12 3 
11> تزوستر 0 
023 غ52123-2 , توطع ‏ لطلتدع 5 
كثتزة اطا اتقصار طم 3111م رمتت[جح متصرر 2 
5غ للم "اال غتعولا" أعدار [17+1152-1تطاع ] , تمع وعل ا 
"امت معدلا" داأولظر 3 > 1111211 3 
شباءة طانالقصا اأقعر تتا للقه - 
لاق "خنوتمطعودموع ل" أغدار [1:«#عطندة+ ترطع ] , عتمع دعل لا1 
لا ح زومر عمتلاء , عتياع تدوعد 11 
"نوزمتاعوممدع 1" لاوراظر >3 > 1111211 12 
عالمقط عانالنادهم تاأويظر 33 1311511 13 
كمع ل تعد داع جار كت 3108م رمدتاع عاتصور 14 
كك لقعم رطعم |أقعر >1 للقه 15 
كع للة "عومدوعم" عط أغدار [ 15+ ترطع ] , متمع دعل 15 
لا ح يزمر تلع , عتاياع تدوعد 1 
كان_طل"] باعراظر ت1اء 11211ت1 15 
عا اأويظر 3 > 1311511 1 
اماع 1 لاولاظر >3 > 1111211 لات 
تالتكت اأدودظر 17ج 1111511 أت 
قوزه طعودددع 1" اإقار يعتدت للقء ع 
:1-111 ا 
مده ه01 1 ك1 3" مريعتت هت 111012 -25 
ككععمعط زيزع اأقار يعحتدت للقه 25 
لاء 1152123253115 ' طت 23 ته 115 6 
لام الل ةد هصق 55 112 ' طت زد دزت تا 2 
لام '22دت 1 1 قتاذك :112115111 ' تلك اساحرة لات 


2003 15ت 1 1 2لا لد 
حيث قمنا بالإستعاضة عن حيلة اقتناص النصوص داخل الشيل كود .. بحيلة 


أخري تسمي وذ الملا 8اء2 .. ويتم فيها تحديد قيمة إزاحة القيم داخل 


الشيل كود كالتالي : 
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132+ 1ه 
:ع0 
مع ممم 
13ع0 01556 ,مطهء طنَاه 





حيث يتم دفع عنوان تعليمة الإجراء 3 الي الاستاك ونسحبه في 
المسجل (0ع .. ونطرح منه إزاحة 063 .. فنحصل علي عنوان نسبي 
نستطيع به عنونة أي إزاحة لمتغير داخل الشيل كود. 


والتعليمة 3| من تعليمات 1751111650105 10301750 .. تستخدم لتحميل عنوان 
المصدر ع6ل501 في الهدف 065113500 : 
>50112 ,581231©2ع©0 هم 


والمصدر يجب أن يكون عنوان ذاكرة.. فمثلا نفترض 36/ا كمتغير ونريد معرفة 
عنوانه فبدلا ان نقول : 
73 'لنطك 022 رمطء ه11 
يمكننا استخدام : 
ةا ,رمطء 3»عل 


ولامقرفة القنيئة عتذكفنو ان ذاكخل التتميل كوة ركوؤن #التالى 


[2321غم فن مهت ]| رمدقة :1:83 
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كاية اليل كو 


البحث عن 132ع2ع»! 


إلي هنا قمنا بكتابة شيل كود .. ولكنه كود ثابت علي نظام التشغيل . 
بمعني أن عبوات الذالة 10301187857 «يختلف علي أنظمة التشغفيل المكتلقة 
وأيضا من الممكن أن تختلف عناوين الدوال باختلاف نسخ ال 6ءقم عءارمع5 
للنظام تفسنةى يففدي إرنا تتاف الإصهدارات الحديدة من الفلف: 


وبالتالي سنحتاج أن نجعل الكود مدعوم علي معظم الأنظمة .. وهنا سنقوم 
باستغلال التطبيق المحقون به الكود .. وبما أن جميع التطبيقات التي تعمل 
علي ويندوز تقوم بتحميل مكتبة 616132 .. فاول خطوة علينا القيام بها هو 
معرفة عنوان الموديوك للمكتبة 32اع©]©»| المحملة في ذاكرة التطبيق. 


وتوحد أكثر من طريقة لإتيان عنوان 72 منها الطريقة الأكثر شيوعا 
وهي الاستفادة من بنية 8ع« أو >اعوا8 أمع امم لامع ووعع2/0 .. وهي بنية 


عقر اتاتها بواس»طة نطافر الشميل لكل تطيى هما علية : :اتتضوك على 
معلومات عن هذا التطبيق ومنها عنوان موديوك مكتبة32اع5اع)| .. 


ومؤشر تلك البنية يكون دائما عند العنوان[6:]308 من ذاكرة التطبيق .. 
فتقومر بالعصول: على عنوان تلك النقية تمر تذهت إلى الاراحة[0)] من مؤتض 
تلك البنية وذلك للوصول إلي مؤشر للبيانات المحملة للموديولز . 


وبعد أن حصلنا علي هذا المؤشر نذهب إليه مع إزاحة [©1] لنحصل علي أول 
مدخل في قائمة أولية والتي يكون بها دائما مؤشر لعنوانت6|32م]6). 


وتقوه باللخصول علي الغنواة: فى الفائفة ضهن إداحة فيمتها| 108 
والكود التالي يقوم بتلك العملية : 


035 معط ح نروع , [15:]301,كاقع /املا 
0]طأ ع1نا1ل110 ووع8]060*” -ح يراقع , زطع0+<«3ع |,لاوء /املما 


أ5ا! عانا0ل70 ما لإتاأمع غأ *”115‏ 7لاوع , [1+لاقع], عاهع /املا 
15 ع5 لامآ عنااق/ا علا أع0 , إلا |,كاقء /املا 
5 ه6355 32اع0يرع»ا ع 2<اطع , [زم08+<3ع ],لاطع /املا 





وبعد تنفيذ الكود السابق سيحمل المسجل لالع لدينا عنوان الموديو”ك 
72 .... وهو علي النظام الحالي يحمل القيمة[08000001// ]. 


ملحوظةه : المسجل 15 هو مسجل مقطع- 'عأواوع 50701 ونظام 
التشغيل يجعله يشير دائما إلي البنية8ع | او >اع8!0 أضعصامهم ]لامع وعلط | 
وهذه البنية تحتوي علي معلومات عن التطبيق بالإضافة إلي احتوائها علي 
البنية 8ع2. 
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كتابة الشيل كود 


الوصول إلي عناوين إإحراءات851 


إلي هنا حصلنا علي عنوان الموديول 32اع0)ع) .. ورأينا من خلال الفصل 
الحالي كيفية استخدام إجراء 48.81 عن طريق تحميل المكتبة الموحود بها اولا 
بدالة ٠030111319‏ والحصول علي عنوان الإجراء المراد استخدامه بواسطة 
الدالة 5ووع0©]8208001. 


وبالتالي يلزمنا الآن تحديد عناوين كلا من الدالتين ١0301131‏ و 
500 في حالة إذا اردنا استخدام اي تابع 4581. 


وكلا من الدالتين موجودتين في المكتبة 32اع7اع)ا.. وبالأخص موجودتان في 
جدول الدوال المصدرة في مكتبة 32ا©0]ع»ا.. وهو جدول يجعل التطبيقات 
الأخري تستفيد من الإجراءات الموجودة بالملف الحالي .. وللوصول إلي جدوك 
الدوال المصدرة نستخدم عنوان الموديولك الذي حصلنا عليه ل 32اع0©»| ك 
35 10306 لملف له ترويسة غ2 متثل الملفات التنفيذية بالضبط .. 

وبالتالي عند العنوان [768000001] .. تبدأ ترويسة ملف تنفيذي .. نقوم فيها 
بالوصول لقيمة //ا©1310|_© لمعرفة بداية ترويسة 1/1532.. وقيمتها هي [28]. 


ثم نقفز إلي هذا العنوان ونضيف إليه إزاحة محددة وهي [780] لنصل إلي 


البنية 081101141_115410132_عاتم/"!1 .. أو بالأخص إلي أول عنصر في 
مصفوفة البنية /ا03]310166601ا .. حيث اول عنصر هو مدخل جدول البيانات 
المصدرة 0151ط 7_2[ لاع_/ا01 1اعع1م_ع 6 م1 


للا ٠-51‏ 10137 بال 101 شاكنا_ طواضا". 
8 011 انآ 5 171213-02 
2 011 انآ ©1517 
11111085 من .. هاا 


[لال.متاعدععما] - االا وعرمامعع ١ن‏ 
كوصملععد5 عاع 


اموااعع5 عراة"! اعى انا قط مك1 
انزع 0000262 0000016 مالم ممعم زم مجع اال 32اعممعع تعاتط يك 


000067 00164 | هدك بمماعع نان اممميع لدع | عدن لقا 
]ملع 1 غلا لقا ا 
علدع ل علاء لقا 
انا لالانانا 11512 لالالانانا ع5 لماعم مانا دمر[ علدة لا ادددنام0 [2] 2 
عم, ‏ لالالاتةلانانا لا 11انانانانا | تابتع رصعاعع آنا عع رامدع م [ع] عع رماععزنا ماد نا لعا 3 
568 5لانانا 0001014 | عداك م معاعع آنا ع لامكعع [:] 5/عوقع 1 مدلاءة5 لها 


بوماعمزن] اردمع نا 
لانن نانان 5م 1 انانانانا | قتع امع ءأنا مدلامعدورع برود اع عزن أندمهما خا 


لانالالاناذالانا ا” 1 لالاناتانا | عماك ب إفاءعءانا مدتامعد يدع 3 برو اصع زن] عد بمعع م كا 


أغتعط, ‏ اناك لاتنانانا 55 [لالالانانا بقاع رصاعم انا اصملر[1 - 
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الفصل 3 كتابة الشيل كود 
والصورة السابقة توضح بعض المعلومات عن مدخل جدول البيانات المصدرة 
متل : 

0 - 8+78غ - "الإزاحة" أع0175 
وكذلك العنوان النسبي 81/8 وهو 2620 .. وبالتالي للوصول الي العنوان في 
الذاكرة : 

8/8 + ع635 م030 - ملا 
0262 - 2620 + 7800000 - لملا 


وعندما نصل إلي العنوان [©7©80262] فسنجد البنية التالية و تحمل الاسم 
107 087_015ماع_ع 6م١1‏ وهي تحوي بيانات الدوال المصدرة : 


ا 1 لكر انطع 1 1 ا لكان لطع اتزوا كل 


2 8 ره 5 00222222215 1 
9 0110 الاما م320 5 5 © 11112103 2 
5 58 مه 251ع0217 1133 3 
2 كلما مه 11120217251 4 
2 انا 2ط 5 
2 011 اانا 12235 6 
2 011 اانا 201511165 1111 7 
2 011 اانا 5 20121 ا 8 
2 م01 اانا 015171121685 5 5 201012 9 
2 م011 ثانا 5 5011 5 200112 10 
2 011 اانا 012202-25 5 5 20012 11 


101158010153 20151 826 واه 1 
أهم عناصر تلك البنية نتناولها كالأتي: 

1 - الى : وهو عنوان يشير للاسم الدخلي للموديول .. وهو معم لإنه 
من الممكن ان يغير المستخدم اسم الملف ع قمعل .. 
وبالتالي فسيتم استخدام الاسم الداخلي. 

2 - 14116110115 1:011 1111112 : وهو يحمل عدد الدوال المصدرة بالموديوك. 

5 - 1761:011131165نالظ : يحمل عدد الدوال المصدرة بالاسم .. حيث يوجد 
طريقتين لتصدير الدوال .. الاولي عن طريق الاسم ©5300 لإ 
والتانية عن طريق التتابع 010131 لإ5. 

4 - 1110112110115 201016550 : عنوان نسبي يشير لمصفوفة تحتوي علي 
عناوين نسبية لجدول به عناوين الدوال المصدرة بالموديول 
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لانانانانانانام 


لانانات لايك 


لالالاك 


لالانارا59ط 


رملللة رسكاكة صل نزن اكتكرن 


6 


5 
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لالانانالالاتاط لاذاناتمطيم لالالات لانالارا 8988 كاتني لالنااار 
لالالالالالالات لالاناعضت 2 لالالا] لالالاناطاادت اين 
لالانانالاتانا] لانانارا عم لالاذانا لالاناراط مع ادزام عرد دلرلة اا 
لاك االادوإفلاك) | ضام البرك اام ثتديم دعدا راذا 6 0 . 6 

ا احج 

- 00 1 2 ّ 
ولاصإناع| كالاتوإدنا لؤترك | لإعلناتة واداناعر | لإعلنات برج لم عللات 2 عِِ إْ 2 ل 1 

1 >3 ثنر ل | 
ناتاه 5دذنو للم عالناد ولام إلاء|ك [الاذانا] “اكلا تلم لالانالاط 32ت 0 - . ١‏ ٍ 5 
تنما ددن 1ل عالناده لانانانا] اط تنام لالالارادتم8 ا ب 1 - 1 

للا : 

واننما 055 كا الاذزإنالاك ناذالا ] مم تنام لالانانات اام 0 0 - 
لكا اللاراكان ول الناكك لالانانا] طم نام لالالازالا58 9 


وكآلاع. 


سهناء الذواك المصدرة رالموذيول 


]ا التالاكا وكا الادرإنالاك لانانانا] وأطزلا 
5ك لالانانا] لاطت [ال#انالام لانانانانانانا] 
له الناكت لالانانا] 8519 تتام لالانانا 999 
لانانانا] وا95 لالت لالاذانا 

لالانانا] ياعم لالم لالانانا 

لانانانا] ئلا انام ]1 
لالالانا] لاست تتام لالانانانانانانا 


3541ل ساست عرااك 


“انلام لالالالاناء؟59 


الات ئردكرواصنا 
لبإعادلمردلكادنا 


[الناك عوتب نزعللاك 


00 تحتوي علي الترقيم التتابعي للدوال المصدرة 


01١32‏ : عنوان نسبي يشير لمصفوفة 16 بت 


تلاعلاعدزدلإدراده 


- 800165501311165 : عنوان نسبي يشير لمصفوفة تحتوي علي 


ا كلنا13 


بواختصارا يتمتطلق قلية: ضن الات 


00 





01 


كاية اليل كو 


حجم البنية 087_01557081ملاع_ع 11186 40 بايت .. والإزاحات بالنظام 
العشري والسداسي عشر موضحة كالتالي : 


2111 1011 ناظ1_11114غ1آنا للضمطظ_اأحاله111 


9 7 نالا 11 3 -151 11ت 1131 نا 

4 7 نالا 11 لاقت 51 12ت 11 1112 1 1' 

0 7 انا لآ 1 1-15 01 113 
هش 11 8 رسن 1 11-01-1215 111 
هي بت قي 1[ 7 «لدرس ا -1 1110-1 
10 - 15 هر آلآ[ 118552 
14 - راض د 1111 10 1111-1-5 7ن حت للاتنا آنآ 
868 - تي 2 1011ل[ ك خانتقة 11د دك جتنا 11 
11 - 8ت هت لدان[ 111-15 027 53 2 خالا 
لاض - متك ب تهنا > نت 0211 تت - 111ل 
4 - 3656 د 1ن[ 1ن لاقت 0211 3ت 2 خا 


-1]1ظ 181-1111 111_ 111لا لمامظ_اجالك11 1 


إلي هنا عرفنا أن هذه البنية تشير إلي مصفوفتين وإلي جدول به حروف 
نصية لاسماء الدوال .. وسنقوم بعمل مقارنة للنصوص .. وهي طريقة 
تستهلك مساحة كبيرة من الكود ولكنها ضرورية لفهم الموضوع بصورة 
مبسطة .. ونلاحظ ان كل اسم دالة ينتهي بحرف ١١‏ الالاا.. هذا الجدول مؤشر 
بعنوان هو 8001655010/30065 .. بحيث إذا ذهبنا إلي هذا العنوان سنجد الأمر 
علي هذا الشكل: 


ا ©#لاهلا 2< 551 >< م015 + 5ع233 500104 | 50 0 
86/316802 | 7804873 [0 * 4 + 70803528] 0 | 202020200 


4م6006 20102ؤ2 [1 * 4 + 762803528] 
/الامممغمل0م 22018 (2 * 4 + 76803528] 





فمتلا العنوان 28001655011/30075 هنا يساوي [803528)/] وإذا ذهبنا إلي 
هذا العنوان وقمنا بعمل إزاحة بمقدار (0151//ا0ا كل مرة .. فسنحصل علي 
قيمة بها عنوان الاسم 51 والذي يشير إلي الحروف النصية للدالة التي نريد 
الحصول عليها كل مرة. 


بنفس الكيفية إذا أردنا معرفة عنوان الدالة .. فسنعتمد بالتأكيد على العنوان 


كمون ولخ 50وع 00م .. والذي يشير مضتو بها قيم مؤشرة إلي العناوين 
علي هذا النحو : 
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عداولا_ | غع5/ن +ا؟ 4ن :800 | <50 | 
 ]70802654+ 4*0[ | 70806634 |‏ | 0 0 





الآن قد “تهر توضيخ حمية النقاظ .: ؤلهر شتقى سوف كثارة الكود الشافل 
لجميع النقاط السابقة .. وهو كالتالي : 


:ان ةعادة 50 اأعاد ‏ 1[ 

عالمقط_دذاعل الى 2 

ماع ممع تعاتمقط_دطاعل 3 

عالمخط_دطاعل اعد ]ام راع دالب 0 

ِِ 

[دانات ]:ى أرجردع وده 3 

[ اعلا زوع ]إربردع دودر 0 

زا ا عبرزوع ]ر, بردع ودر 8 

[:تء إربردع موده 2 
[اأتلاء بروع إ]رببباع موده 10 
مكنا قررفيط عضا موقط افصععا عروئد ر عتططاع [اعمععناط_ + مداع ] عام لعمسل مده 11 
1 
ل 
:أمة_ توآ 14 
ترمات عط د زوه زر [زاءت + عرماء ]| رعردع موده 15 
شاكع عاناة 1 وكتمللث تدمع ع أله ب [لات” + بروع + برراع ]| ,المع سدم 15 
عالامئطة غز عياق دس ر بزطاء ,الع لت 1 
قناع ومعومددكتان دوع ننم ح :له ر زانات + الع ]| بلع تمده 15 
عاألامئطة غز عياقم ر بزراء ,بلع لت 1 
ا راض كممأأعصبط الات تترفع ر تكست راناء لات 
تمدها_أمة 21 
تلعومةحاء أ موقط اأصصعها عوفدم ر [أعمعععاط_+ مناع ]ل عام لعمسلبججباع مده 2 
كقنرةل"تانمعط دورط" معرمم سدم ر [15 + الع] عام لعوملببعع ردك 2 
الات محوز معقطء قمع لصطعدم زر عمدك_امة عر د 
شاكع ألموة ممأأعولظ ع أوع ر [1 * برعم + برلع | ,زوع تاودن 25 
عأادئكطة ؛ز ماسر برراء رآىع للت 2 
إذقت ذا إقلرامم عحمقم ممأغعصبط بنممع زر زاىء ]دع عنسدده ات 
ا 
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الفصك 3 كتابة الشيل كود 


قم لادع_امرة 23 

ك'از معطتصطبب عاص مذ عمعيسر تطانالةصا لا3 
أمدكاا,ى أصمعه ""كربصةطنالقها" زر 231 
عوخناعمة؟ وذ ألنت محصرز معط ر 32 

لادقل دع ىو 33 

عوع عدا عزرل 34 

[نداوع ]ردح ودر 35 

' الما متوع ىو 36 

موعن عدا عزرل 3 

[تج+اجع ]ندع منودر 32 

تام رنروع رلك 35 

عوع عدا عزرل الك 

لععلم]ز ك'ز معطظ؟ معط عمو طاع عط زر [,لدنندعةت_+ع راع ] ام لعويسبل منوددر 41 
عب وى ,, "قبصةطنالةها" ممتتعصيط نامر َك 
دط عللقنمت هذ منودرز لدة 1 ع ودنةاد أمقى زر 3ك 
ككةللة ممتغتعويط عط ممحم تمر ك 
شاد ورحناز 0 

ص 

ك"از معطتصطبب عاعصطاء هذخ عم سر تعدم نا اموا لك 

أصم كا ءى أصمعه "كوم للفء دم صمت" ر 5ك 
أمة لتقم نط أللت محصرز معط ر 45 

داع ان زوع ترحقى لنا5 

أمة_أنزعم عول 681 

[نداوع ]ردح ودر 52 

"أدبم برقع ترحقه 53 

امة_أنزعم عول 54 

[تلد+اجع ]ندع منودر 55 

للع تدع ررحدىه 56 

أمة_أنزعم مول مت 

[<ا+اكع ]نح منوددر 52 

كت ,3ت نلك 55 

امة_أنزعم عول لاخ 

لععلم]ز ك'ثز معظ؟ معط غمو طدّع عط زر ,[ذنناقاعت_+ مراع | عام لعويسل منومددر 81 
عبب دى,, ""كومرلل قحم طعمت"' مماغعويط نات زر حْ 


«للمشئامدت ذا قيس لئصوة لدة 2 ع ورفة؟ر أقى : 53 
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كتابة الشيل كود الفصلم 3 





لت اعم 
كراي'؟ا وممأ عدر انووم للش د زهت ر زاء1 + الع ] ربرمدع تمده 
عأامئكطة ؛ز مماقس رز عزراء رعزدء لله 
فاع 0655لد ممت ءورلا د رمع ر [برعع * 4 + بروع | يبروع ماودو 
عأادئطة ؛ز معاقس رز عزراء عزده لله 
كلاأةاك ح زات رز [ذداداكت_+ مداع | عام لع سلبججناء ددر 
ممأأعميط أمععرره عرب معصطئات عمأمععل معطار 
"ل شتصرطنوئ" رن '"ى انالةقها" 15 
اعتناء رمك 
عوضن لفك ها محديز معط "“رطنالقها" تمم كاز ع5 ع ززل 
كك للم ممتتديطظ عروئه هواة ب تت عمل :لشم ارق ترطخالدها_+ ماع ] عنام لعميسل مده 
للكت وءنانالةها مان 
أمة نهم عط ما ملز معط لمق ر امرت_ متعم نإتلال 
ردك معحواة صندقد هذء دل زر ا 
ممأتعصيط "ل رشعومطومت" زر 
ترعتطاء ردك 
امرت_أنزعم علرال 
بتدع,[ءللقدممطععئ_+ راع | عنام لعويسل مدهو 
د أرامضح ضط عاومرق رلته مكمصعمز عبرم عرصل ر تامة_امزعم 
ممما عطة دغ ياعقط منورز قمة أمة انعم عطءر 
ست هايا 
مددا_امةت ورتلال 
كأكادع كعنم ل اتسصطودرة] قط تقطعمم عع زر :دلك_امة 
عبرا كقووة[300 ديم عط؟ تأت طغصط غدو عت معط زر 
علمه عورهد عخمرن ما منلقمعم ماعهر لمة ,, لعقمر 
ملع اماك اناعم غنات عاألعمقنت نا محدراز مك ر عت_حع مت الال 
:اط_ اقيمع 
للقعدةانالةما - أوع ر [ لقم ءرةنط الددا_ +ع ماع ]| تام لعمبسلاعع سمدم 
للف مرطهة ح ألم ر [ءللقعوءطععئ_+ راع ] عنام لعدسلرالع سمدم 
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الفصك 3 كتابة الشيل كود 


أععتان '"|ال عترهولا" *” دجم ر [2تعدرا_+ مداع إبعع وما 33 
"الى #ترعونا" لويس نر برع (أئنا 100 
قبصةطنالةها أأةء : أاىعء لاق 101 

عالممط الهم تتممون عرماى ر ددعل نتععوراط_+ راع | عام لعمسل نسدد 102 

أمعتان "كرون موددعم1" * داوم ر [::دطوكى_+ مداع إببعع دما 13 
"بترو قو 5وت 1لا" داورظ ر برع (أئنائر 14 

عالدقط عامايهمه "عتترمور" ناورظ ر بددع ١أئنائر‏ 15 
ككمرللئءوم زفت أأةء ر آل ااىء 1 

للد كردم عوددعه1”] ع عللدتصمطوعهم زر عتدع,[:03د:«مطوكخى_+ ررجاع | تام لعمسل نسدد 107 
امعتان "موددعمم" *” دانم زر زوكم_+ مداع إبسعع دما 102 

ذا دراه ر بلع بلع وبر 10 

غات_نتا اوراس ر بدله (أئنائ 1110 

11 طورس ر براح (أئنائر 111 

أنذت 1 لأوراظ ر بدح (أئنائر 112 

ذإل ]تباتك تاوراظ ر بدلح (أئنا 113 

كرره نا عوةووة 1" ااقت : بردع لأاى- 114 

:“المع 115 

أمعتن "ددم مطززوع" *” د زيم زر [دددعه :مأزبدزت_+ وداع إببرعع وع| 11 
"ووم ترط ززرع" راوراظ ر جتعع ادنار 117 

عالمقط عانويهم غ#تاعصهععا اورظ ر بتاع تأدنام 112 
ككترل لفو وم طزم تا أأةء زر آل اادىء 113 
ككةعمرطززرع أأقنة زر بددع اادىء لا1 

1-21 

آنا عل عدقطعوذكلها 1 

آنا عل اعمعاط_ 123 

آنا عل كلأ ات_ 124 

آنا عل قزق نط اتةصا_ 125 

دانا لل اشع وام د_ 126 

نااال. عتعدن' طال لم 127 

حاذا لل ولاط_ 125 

لا شفئزمتاعودددوع 1" ذال 1715_ 125 

حانا لل لةئنصطودلر_ 130 

نايع 3ددع اأعطدك وملؤالتم؟" طال 1750 1131 

لافعععمءط اودع" ذال كع مااع 132 

1 


134  دطعا|‎  صقععمت#‎ 
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الفصل الرابع 


عوسي .25 





ع1 عاطدخأبءعغاغ عاطده6ره2 جح 0غ ع00) أععزما 


1. المفهوم وكيفية التطبيق. 
3. شرح شفرة البرنامج 


لوت اه 





- المفهوه وكيقية التطبيق 


يوحد عدة طرق لحقن الشيل كود داخل الملفات التنفيذية511©5آ ]2 مع ضمان 
الحفاظ علي أداء الملف التنفيذي .. ويطلق علي أسلوب الحقن هذا عم 
0ع .. ويمكن أن يتم بأي من الطرق التالية: 


حقن الكود في مساحة فارغة في أي قسم 562000 .. ويطلق علي 
هذه الطريقة الاسمع/ا3-) ع000). 

إضافة قسم جديد 586010 /ثاعل[! للملف ووضع الكود به. 

عمل تمديد للقسم الأخير 5666010 ]35ا 272660 والحاق الكود به. 


والفكرة الأساسية هنا .. هو توفير مساحة غير مستخدمة لوضع الكود بها .. 
ثم تعديل نقطة بداية الملف التنفيذي 50106 لتأمع ليشير إلي بداية الكود 
لديناء: ومين تفر تتفين الكوة:... والققر للعهذة إللئ.النقطة الأصلية ليداية الملف 
التنفيذي. 


ولتطبيق هذه الفكرة لابد وأن نتعرف علي مجموعة الدوال التالية : 


ه دوال التعامل مع الملفات: 
عاأمعم0 - عاأععاوعر 
لجع 
ه|إعاع ]اا 
06115172 
إعأماممع| ع5 
عل موماءع105/) 


وقد سبق وتم شرحهم في جزء التعامل مع الملفات .. وتوحد بعض الدوال 
الاخري المكملة مثل : 
6106314110 
وثامم ةلاع عأوعن 
ىع لام جل 
111 0/داع لا ادب اما 
ع1 0/اع/ام 3ساصنا 


الدالة الأولي عوااكاجط610 هي التي سنستخدمها فقط وباقي الدوال 
ستستفيض عتها بذواك التغامل مع الفلقات السايقة التي درستاها. 
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داله ©والذثقاجط616 





كعازنا أن تاعطمرزلاض لع الاععمة عطا معلةع مااة ضمتعصرلة عمالظاقطماحا عطا 
مر 5ا معطا أتاعصصصسمع اناك مكوربك هعضا عط ضا .مقعط عط صدم] 
مقعط أقطمانت غطا عضة مقعط أقعما عطا مععضاعط ععمعءد ]لان 


أعهالاكاةطماد انان احلا 


5 لات اقلأة وملأقع داق أععمزناه ثم رتك [ ااانا 
عأةعمااة ما عمعائط أه مولام كم كج اباك اغا ذا اانا 
١:‏ 
معاملات الدالة : 


المعامل 13095ئانا : وهو يحدد خصائص البلوك المخصص من الذاكرة .. 
ومن بعض تلك الخصائص التالي : 
راع 1ع _الااع إلى رج :أكرة ‏ 


قط /101_اع لان 


725011117_الاع الى تفيقة الذاكرة المشخصضة رقيهر ضفورة 





المعامل 5عالإاللا0 : وهو يحدد عدد البايتات المراد تخصيصها. 


عند استخدام مع”«1[ع_01ع61/1 فإن الدالة تعود بعنوان البلوك الذي تم تخصيصه 
في الذاكرة. 


وسنوضح الآن كيفية تصميم بريمج يقوم بحقن كود في برنامجع<30.6مع]0/١‏ 
حيث عندما يتم تشغيل البرنامج سيتم إظهار رسالة نصية أو أي أوامر أخري 
تريد تنفيذها تبعا للشيل كود الذي قمت بكتابته .. ومن ثم استكمال تشغيل 
برنامج 30مع]0/١‏ مرة اخري. 


وسنستخدم طريقة تمديد القسم الأخير في حقن الكود .. لإنها تعمل مع 
جميع الملفات التنفيذية بدون أي مشاكل. 
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> - تصميع البرنامج 


واجهه البرنامج ستكون علي الشكل التالي : 


تاساك ا مل 


إعبمعع ا احك مرا 


وموضح عليها أرقام معرفات الأدوات والأسماء كالتالي: 





053 عالت 1ل 


#بمة ل #بمة ل 0# 


لاع ماناناعط_111 8 - 1002 [ناع]لةا_لاام يجيا 





اسم المشروع هو [طع< 06ع171] .. ويحتوي علي ملف شفرة البرنامج باسم 
[ماكث.عط أ1216] .. وملف التضمينات [22.1922 11©6] .. وصندوق حوراري 
باسم [55.019 غع1716] ويحتوي الصندوق الحواري علي زرين .. الأول غ+©1116 
ويستخدم لحقن الشفرة داخل البرنامج .. والتاني 0+ ويستخدم 
لإرجاع البرنامج كما كان وحذف الكود المحقون منه. 


والآن نستعرض محتويات الملف[58.126 غ©ع116] 


كلل كتتد اتات عاعبا دما 1 
عضا عداعصهعها عدباعما 2 
عضل عتعذبا عدباعما 3 
عاضا 32 أدتصدنا ععباعمز 4 
عامل 1322| اعحاك عدبادمز 5ك 
عاتلل ع تتلكدمر عاعبا دعصا م 
7 
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طنا تاعمععها حاأاعكباعما خ 

دزا 32 عذبا طاأزا كاعم ه 

طزا. عت اأعقصحنا طاأاع دباعم ناا 

دزا 32 اعداك دااع دباعم 11 

دزا دمر طازاع دباعم 12 

13 

قت , 08 ا ك تلت قط اعحمطلت كت تككش تع عدبادمز 14 

15 

ناث عاشط ا ,ناش عات عابتا ر 1 لكالا رناللضاط: رفص عصعطوانا 15 
1 

15 لا, 13 

11 بانع 1تانااث[الا_نانا[] 19 

1لا لاع احالك1_لكا | ب لات 

تالا بانع لاع انا_اععا_لذا اث 1ت 

344 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 24 34 34 24 34 34 34 34 34 34 24 34 34 4 4 4 4 ةر شا 





1315 ذه 

ل" ددعم[ عم" حك عم جمدم جع 
لا" عنت, معدم" كنا ات" 5ه 
(لاا تناك 512 حاكت !2 ألانا ذخ 
الك حاكت االالكانا مت 

اآلالات 58 52-25 ذم 

م 

4 44 34 4 34 34 34 34 34 344 34 34 4 34 44 34 34 34 34 34 4 34 34 34 34 34 37 37 34 34 4 3# 3# # # # # زر لات 
313 . 31 

7 مك 1513-5 2د 

7 د وانانا تد 

3" عااعاط جد 

7 لاا 8 35 

7 ان مكماما قة 

7 لاا ععواناما 3ت 

7 د 11130286352م| 35 

7 د محا ربعل*ام| 39 

7 ان 111[2-1م| ذلك 
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الفصل 4 تلويث العم 


7 لالد ع2 تالة] 41 
7 لمالا عصطم| 2ك 
7 ادا 3522| تك 
7 الما حذا| أشمازح جك 
7 ادا وا |اث دعد كه 
2 00 11302 1الاص دك نك 
7 إالدا الات مك 
حدم [ اراي | حجان +015 5ك 


34343474747477 34 34 +3 34 34 34 +3 +3 +3 34 34 34 34 +3 +3 +3 34 34 37 37 +3 34 37 37 37 +3 37 +3 34 7 7 3# وك 


السطر 25 : متغير به مسار واسم الملف المراد حقن الكود به .. ونلاحظ 

هنا ان المسار سيكون نسبي 235 3]06ا56 أي لابد وأن نضع البرنامج 
ع“اع.30مع20 في المجلد الحالي الموجود به البرنامج..حتي تعمل دالة فتح 
الملف بنجاح. 


السطر 28 : حجم المساحة الفارغة التي نريدها للكود تبعا لمضافعات 
أناع10اضو1امع!1 .. وقد قمنا باختيار مساحة مناسبة للكود وهي 512 بايت. 


السطر 34 : متغير سيحمل مقبض الملف الذي يتم التعامل معه. 
التشظر #35 متغير ستحمل.ظول الفلف. 
السطر 36 : متغير سيحمل مؤشر الملف المحملة بياناته في الذاكرة. 


السطر 37 : متغير سيحمل عنوان نقطة البداية الأصلية للبرنامج 
أمأه هلامع أومأوانه 01 ودوع600/ 


السطر 38 : متغير سيحمل عنوان قاعدة البرنامج.. ليتم إضافته للعناوين 
النسبية والحصول علي عناوين مطلقة. 


السطر 39 : متغير سيحمل عنوان نقطة بداية البرنامج الجديدة .. والتي 
سحكون غدوان يداه الكود المحقون 


التسطر 40: متغين سيخمل مفؤشر الكود المحقوت :فى الذاكرة. 


السطر 41 : متغير سيحمل عدد الأقسام في البرنامج. 


/1 


السطر 42 : متغير سيحمل مؤشر الأقسام داخل البرنامج. 


السطر 43 : متغير سيحمل رقم القسم الأخير في البرنامج.. حيث ليس 
بالضرورة أن يكون آخر قسم في مصفوفة الأقسام هو آخر قسم في البرنامح. 


السطور44- 47 : من الاسم نعرف وظيفة كل متغير وهو تخزين معلومات 
أاع 1110و العا , غ3اع 500101141191010 , ع0111130ع512.. بينما 0101772 يستخدم 
لاستقبال البايتات المقروءة أو المكتوبة من دوالك التعامل مع الملفات. 
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سد 
شفرة اطلف 61.151 111/2212 


1 3 

اعتصم “دضعم ألط عكر اأحدعلاد ادا اعددات, 2 
عاا]| دراعة عد5تاز عام تزدراع35ت- اأالانزت 3ت 

ل 

عطلعط أععاض] عدباعم] 5 

: 

35ل م 

1 وأطعععص )| اعد أعم]ام-لخععءص )| اعحطد أعدااص) بامع 2 عداكدة خ 
02م , 9 

11 

غلا الاصض: 5 عمربادعت 11 

1 

11ت دعاعت :]| أعداد 13 

عاقصحط_طراعك أاادعء ‏ +14 

ترنات حرصم :عا لصودط_دذذاعك 15 

عالدةا_فااعل أعذاأم رات تاباك 1 


زالاك]؛ كارئزدع صم 135 

[حاعناء:ئندع ]| نزدع ندم 19 

اعلا +تنادع]|, نندت دمر لات 

“اقم ]ندع ناورم 21 

زطقراءئاوع ]| خطع امم مم 

تاجات ,[ أعخعععاط_+مناع] عنام متاك “دمر تت 


'أنزة_دماا كه 

[زطاعت + ونطع ]| نزدع ادم قت 

زطمم ع يزدم + وزناع] راقع أصمومر ‏ مي 
نات ,الت 30ت 3م 

[اناج + القم]| ,راع امم يم 

بات ,نادت لوت لات 

ات رثات 01 31 
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مإددا_امك 2د 

اعصعصاط_خمحاع] تلام دسق ,ننداع “أصمم 2 33 
[زاقا + ألدع] عنام ع ادمتاد ينتعت ممع 2 جق 
عدادك_امة غ2 35 

[ك * برعم + بجامم]| رأعع أدص 35 

“نات رادت 300 م3 

[أىة ]| ,ادع امم 33 


31د ادعم_احرةت لاك 
كااضدصا 11 

ادك نتدع دتزلورحت ‏ نك 
انا احا عااز ‏ تك 
زخطامم ]| زجع امم جك 
لالط نزدع تمصع كك 
انا لاعحا عاز ‏ 5ك 

[ 8+ امت ]| زجع بأملمر ‏ مك 
اقنف ,كت مرمرع 2 تك 
دان (لاعها عذضز ‏ 9ك 

1[ تنأهاك_+صحاع ] تنام تاماك “دمر لاك 
الدشاعدا داز 51 


لان طاعجا 53 

"داصاط نزدع دزلورع ‏ كعك 
انزحت_اأئتعم عمز 55 
زكطأزمت ]| نزدع دمر 5م65 
'“امعاتف رننقع نزاكاع ‏ مط 
انزت_اأئاعم عدز 53 
[8+أكت ]| زجع دمر 593 
المت نندت ملع لات 
انزك_أ“ عم عدر 51 
[12+اقع ]رثات لأصممر نمم 
!55 ,4ت حزلكات تم 
انزحت_أ نعم عدر كم 
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الفصل 4 تلويث العم 


2,[ كلأهاك_+صحاع ] تنام تاماك صم كم 
ذم 

' “اتشاعجا م5 

[طعل + اقم ندع صر كم 

#اطاك ,نندت لت 55م 

[ن«عم * ك + نيزحمص]| ,ندع ادم لم 

#اطك ,نندت لت 71 

0 

[ لهاك _+صماع] تنام لامضااء تداع منصمر تم 
ل ئزتاع مضع كم 

ان إطاع5 عرز كم 

تر[ القاعشكت؟ 1ت اكاا_انقصا_+دحاع] تحر قتتصننك منصمر كم 
امت_أنتعم ملز مم 


الماصط كم 

كاطع ممصت لاق 

انزح_ائتعم عدمز 531 

“تع ر[ معشفعم طاعما_+صداع ] تنام تاماك مممر تخ 


33 

'أتزت_انرزعم خخ 

#ناج لا 855 
تدما_امت نمز مت 
3 

2امكد_احرة 55 
لاظ_اعتزع ترز 39 
الك 

5_اع نرت | 91 


[ العاعشم؟ 3ت اطا_اقحصا_+مناع] “لاحر عتندممتراجع دمر مت 
[ اماتشده طاعما_+ترتاع] نامر عندمتتك ,ادع “دمر تت 

[ 32اعذدا_+ ماع ] ,عت دعا جة 

#حات لاقيام 5 

أقت اادع 5ه 

انلقع ,[ 32 لعوباط_+مطع] تلام لممنتك “صلم ممت 
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[ “تمطوعص_جمناع ]| زعم دعا جه 
#حات تأقناص ‏ 9ت 

تدع لأدباح لالا1 

انع اادء 101 

قت ر[ “الفاعتئتدحاوكتص_عطحاع] “تام تتندثتتك “صلم 2لا1 
[وعمص_+ططع ]ندع دعا 13 

“لاص ,زاعع مز +14 

تأقناصطم 105 

تداج تأقيام 5لا[ 

تاداع لأقناص ‏ ”/لا1 

دج تأقناصطم 135 

ددع اادّ 109 

111 

ترتزث| تتنأ نا انانادناقا 111 

[ حاتمنطعو_+ططع] ندع دعا 112 
تداج تأقناصط ‏ 113 

تاتاع تأقبار +11 





انع اادء 115 

أنتت ,[ الع تا تمتطعو_عخدداع] تلام تدك صر 115 

لا تأقناص ‏ ”11 

ادع اادءع 11353 

دع ادراوا تنه علا أعدا , زطفت + يزدم] نزدع صر 113 


“تج حزما 120 
11 


انا للد 3025ل 122 

كآنا اك اعمععياط_ 123 

انا ملم 5لاماد5_ +خ[] 

كلا لالت معفم 31ت اناا _الدصا_ 125 

كآلا لك الاش عد طاعت_ 125 

لا,'اال تعدبا داك ددلا_ م127 

كآنا اك 32 إعقباط_ 1253 

لاركث :م طعودد دعاك داك 0# 5_ 129 
كانا لمك ا ت:ند نا ودتض_ 130 
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لا ,"شع | عمد داع اباتص لامج" داك تاتدوتاعم_ 131 

حالا لات اتلد تدواع م_ 132 

لارعدمعا اعطك ومضصاطاصنتك" ‏ داك 0558_ 133 

1] 

ت#مععادد :)| اعد 135 

داكت 1 

1 

133 51311 

1.9 

اال الكارعاتصوتاعا بعد اطاعى عمامسممز 140 

4ت رع مخاعصاط “دص 141 

ك1 

15ت اتات ماص[ عؤادهم 143 

انلكا 1دانااثآنا_ناناآرعع دم اعصاطرصضحعوط ‏ :ماود دانا ععامئما 144 
اال الكارعص تاوانا الات 145 

لارععععص عط جاع عوام مم 145 

1] 

113 | # 4 4 4 4 34 4 34 34 4 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 24 34 34 34 34 34 34 34 34 4 
149 


بات جات ارثا ؛ مترت مك عاتن ! لذلانا: وكا"#انا نال شئاط ضاثانا عصمح عد ءتاوانا ذا15 


ناث جات ١|‏ مترجدصا 


لاك الار تدع “أداتمنا 
دانااشآنا 1 1ل11_ اشاح د زرده [[, 
مالثياطا حاكباح 
داناط ددح 
نالخاك ا" ]انات_ا#أإشراح د بردع [إدصواص., 
تلك تطشن “نام ع دنفت تحت ندع ددم 
[ تل رع عوطان ]تلام ع نمتمحتاعت دمن 
نا كانا1 انا_لكاع دح ورت 1[ 
[اععل"ا]1_لذا | مددوردع 1 
تاد ععام]_ أ واد |اجد 


5 
152 
153 
15 
155 
15 
15 
153 
159 
ناذا 1 
151 
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عع اوناععه_لذز رمح - برودع [إزدواع., 153 





مصاع تمدع عها_ داك |اىد 154 
الماك 155 

الدع 155 

15 


عدن انا_للابشتا- -يزدع [أعداع, 153 
لارضالخباداروصاداناتصع ععامئصض 159 


عداع, لم1 

عط اشذعحارنزدع ‏ دما 11 
أ خ”/[1 

امع تم 1 

عللها | نزحت تمر ك1 
أ2 5م[ 

1” 

دزتصع عم ناوانا 1 

1 


4 4 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 4 34 4 4 4 4 د 4 #4 م 1 
لاا ااانا عا ١‏ 11 2 ,ناا نانا: ناكاتناك عصعة حتداانخدطاك 13 

عانك_تاكا رع | 11[ درجاكا “اك رواناطنئ تم نعود دعدطاا ععامم 131 

أ 132 

دضع حاكائاضتدلاد 1535 

4 4 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 4 44 34 4 4 4 د د #4 134 
155 

اط تلطا دع 1_1 جاد 135 

غ1 1بالثباناشععا_عانا اكات لدعت رطتحط املد عا اضصعمت ععام كما م13 

دع ماعط صر 133 

غلالاثثا_عا انالكاث ل !_نا[اثم !1ح د :ردج | 139 

بزعا عط تعمد خصصمد") 21 انا رجاكاانتمطك عؤادثتما 191 


ذ" صصح" ١‏ | ك1 1 ا 1631 
ع إعاعومات! تراز 12 
اددع 153 


ا اللالكرما عط رععزكم| ‏ عاعت عيادمئم جد[ 
أندت رعماط أ ادوم 135 


8أ/ 


الفصل 4 تلويث العم 


معإطعقص5ط ,ردت 20ت 135 

نجع ,1 1ل *اندعت_اطاع عات عجان ناإعقتراع_أاع ءات ,عدااكاحقطدات عيادمم م13 
نذتت ,رمرعاكاما “دمر 1923 

عداط ا ردت 20ت 129 

تج اللا لالات 

“نحت راععزضام| “در 1لات 

لارطاتناك أعقااه رعداطا رمعلكاما رعااعط رعاندعع ععادمنما نات 


دادع 11 لات 

(" تمع" ) 201[ تارذ"عالا عطا ممععه خصصكد") 201 ا ناركاكل“#إشسخصطاك عوادمم] 2 لات 
عا إعاعودان! مكل كنات 

ادمع قلات 


متلعااد| راج “دمر لات 
اناشع ل!_ذنانا_عاماش "!1 ام انع عمترياددج لات 
كاناقفك ح- تاك بز عهالرا | ثشلةادااآح_طنانا_عاداش لاا إعاودحا_ع. 1 اتع] 17 9لات 


("تلصصع") 1ك نرر"عط مزاع" تج خملخم") 241 ا تارداكائاستصطك عؤادمتما 21 
عا إعاعودان! مكل 211 

امع 12ت 

بع دح موهمرر_م, [ الت]| 1[ 13ت 

ب( "عجاععاصض] معععات عط" 26 | تا رداك اةائتصطك عؤادثنما 214 

"امح ) 01 | نا 215 

ع إعاعدمات! تراز 21 

أألاداع. 1ت 

1ت 


ماع ود[ا_ت .[ الت] ,الت ولت 19ت 

اتعرععدم] “دمر امت 

كناعناشعل_١لذا_اماش‏ لا[ تام أتت عبادهك ال 

اغالا اش لذاد[ح_ [خل_اداثل"“]1- إع لاد واد .]| التش] 1[ خمت 


كالاكك4لالالانا > تالاعظ , 2 

(" تمصع" ) 11 ناز" عقاع مااع" تج خمل"") 241 ا تارداككاضتصطك عؤادمنما 0 
عا إعاعودان! مكل 25 

الك تنمت 

ل 


/9 


تلويث ال غم الفصل 4 


أضاصع؟ طصع عط[ أن ممع مث عط| اعم 
أختصط تاضعا تدمع لداعث, اعلعدعا ا ت مامت[ اتع] نندت ددم 
ندع معواناما “ندم 


130358 عطا اعم 
عددناع وتم[ اعاعدع|ا اأاحصد طمن[ امت] نندت ندم 
تت رعهد هع د ]اما “ددم 


1302 انأععاك علا عم 
32ت ]نع ماك إعاعدع! اأحصد لطامت[ أمع] نندت ندم 
“تت رع دكن ]معاد بندمم 


أمعمتضوذات عاط عطا اعم 
أتلع متتو أاشعااع, معددع| ا ددلامن .[ أمع] نندت ددم 
تذقت ,حضوا اشمازع ددم 


أعتاضواات أعدااه اوبط امه عطا اعم 
أتلك تاقوا أشصم ا ععك, مدع اقم امت .[ أصع] ,نندت ندم 
نكت ,نوا اشعصد ددم 


5د عمد أن أعطلصبل؟ عط اعم 
كلد عمك نا رعطا سبال" مم كحدصتام| زعا[ امت | نندت عتعندمما 
بتع رععدط لا نتربال؟] بنحمما 


15اطا]عع5 عطا أت عصتضضاوع8 عطا د[ دم 
كاعناشطاط_ ١لظل_عاماشا"ا]‏ أمععادرعصدم| لاد 
ععكم| رامع ندم 


#اعاناشعا]_لذانا] | ناعط_طاماشا"![ “لام امت عرراباككك 
#زحاع زجاع تنم 
ع ددع زم 
أتعدع ا 
تع 5د ناسح عاد [ ”عاصامط.[ احح] 11 





ات 
ات 
لالت 
31ت 
5-0 
533 
2-3 
0 
لألءث 
تت 
لالت 
2 
لالت 
41ت 
وي 
532353 
334ظ 
دلخت 
دآلجات 
ره 
اجات 
2333 
لانت 
1دت 
ا 
33ؤ6ظ 
4ت 
30 
دادات 
لحل 
الات 
نات 
لادات 
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#إتاع عصط 5ت | دما 21 

15د نانح جام | “عتصاصدع , [ امع ] تدع 'ندامما ا 
اداع , 1 

#اعاناشعن]_لذات] [ تعد_عاماثت "1 أمعدزة رأعت دلدت ات 
#إحات اما كم 

عع انا تالفاح :نزحاع الأصنا,. القت 

ناتك 


58م| رامع امم تنمت 
#اعاناشطاط_لذانا] | اعاط_طاحاتا""ا[ نام اكت عرراباك 5ك امات 
#زحاع زجاع زم نامض 


1 .2ت 

عرايا | عااطايثا. 2 

ععطاأةة ٠ح‏ دتنزناع 11 ل 

تاناةنانانانالاالار ععلكأم] إعاعة دحت .زر أعع] دما 2 
مع بعل" عط عأدابعا تا 6 

5ع الععثادبط م" رامع ]| تدع ندمم م2 

كتادناساد ! التصعاك, [ اكت ]| دجت دلدت ا 

بجح طعابنكعلخام| “دتما 2 

تت يتضلمطابن طصع اندهع ملعف , «عاعدع!١‏ ححص امن[ ات مندمم نم 
لانات 

ادناسسد عه أمه ععزك عطا عددع د1: ا 

2 ةق نامع اك[ امع | تزجع ندم 202 

و ااشم| ,ددج للد 203 

بتع رخا دنا شق ها ا تتعدزك. [ امع] أدامما 204 

تع رعد اح اقبط" عد اك" زاعع] دما 235 

اناك 

قار ا 

أت زقك ظ خخ] أعكااه ص خصادع متطصع احخضاواءه عط عااعلض, 00 
[ مدعلا ودنا] ١‏ 20 

ممزعامام| باحك ندم لايم 

#اعاناشعل_كنانا_عاماشل"ا[ “اص انك عرباددة الع 
ع5د دود لآم نندت ندمم 2 

ععاواناما تدك ملاد 20 


81 


تلويث ال غم الفصل 4 


4ت راع سعص_ع,[ أضف] “دم 
كل لدع اه 
34 راطأ معدص_ع,[ أتت] “نخدم 
ع الكناواك صملاععام] كمد , “ملعا ر, سموصر_ت.[ أدف] ندم 
ار 
باتع انا 

كوت 

#اعاناشعلا_لكات] [نعد_عادائل”] أمعدمزة رادت مد 

#طاع اما 

لان ا]لذاعا, 


تأعصاط ثب تممرعمتر عطا صا ععدباأعطحك عط | “ادا 
كا دعماعم ]| اعطدك أصد] إمراعع نخدم 

مزع ا*ام| راتت مندمم 

,الت دوق 

عمإاكطاك تدع مما 

حاك/دصتة حزع”م 


لذا[حاعظ_عا |1 عا ,لا ,نايعا عط عتصزممع| امد عيادثنما 
مادا ندع دما 

512دت حمق 

لارزالاك أع5] أآصئتدع رمصعلكاما بعاتعطرع] ما عيضا ععادثتما 


ىإ اعدو | نا 
عاإعاط عا تصو د ععمات ععادمنما 
أ 





0 
2-5 
كت 
ا 
كه 
39 
لالات. 
1لا 
لات 
تلات 
4لا 
5لات 
كنات 
”لات 
لات 
عر 
لاد 
311 
12 
31 
51 
1 
15 
31 
15 
51 


متاك تاداع 1112_] حاك نامدة 


ع لحلل لوو لجوجو حو وو ور جراعم 


5 
0 
1 


انا اللا أك”ادناع؟ا_ا اخاد خدد 


غ1 #1الضاناشع»ا_-اناراقاه “العلدت _رطاوط "تعد رعا تع اضعمت عوادمتما 
تح رعازعاط “نخدم 


عه 
ات 


052 
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عالاثثا_عانالأافل!_نالاف"“ل"ا1-- دده 11 مند 


بز"عااا عط معمه خصصمت") 241 ا تارداكلكاشتمطك عؤادثنما 32 
"ضرع" ١‏ |24 | ا 32 

عا إعاعدمات؟ تراز 3310 

أألادات. 331 


الالالك]رمازغط رععزدكعا| إعاعت عياممنم مدد 

“دع رمعا 5 اوور 333 

ومعإخطعططنزدت دراك 334 

4ت رمعا ط] ادوم كت3 

ندع , 1 [كالهعت_اطاع كان هان باإعقت]ع_اماعاات ,عدااتادطادات عياممم 3365 
“نت برمرعا*اصا “ممت متت 

522 :دكت 03ت 335 

لارطاتناك أعقااه رعداطا رصعلكاما بعااعط ربعا فدعع ععادمتما 339 


ددنزدع 11 لاو3 

"اصع" ) 261[ نارز"عااا عطا محعها "دك" ) 201[ ناركاكلإستخصطك عوادمنما 341 
هموما درضاز 34 

الات تلت 


منعااما راتت “دمر كك3 
نافع لا_دنانا_عداش "!1 اص انع عمربادودةت 2 كود 
عاعالا | ثشلةادااد_ذدنانا_عاداش ]1ح إعاودما_ع .1 اتج 11 مك3 


(" تمصع" 1ك ا نارز"عط عأات"” تج خملخ") 241 ا تارجاكائاستصطاك عؤادمتما 34 

عا إعاعومات! تراز 345 

الات ولت 

الداع دا مودصم_عم.,[ النص]| 11. لكت 

("تلصصع" ) 241[ تارذ" تعاععاض[ غمص عز عط" |36 | تا ركاكئاغتصطاك عؤادمتم] 351 
عا أ عاعود | مكل 352 

ادع تكت 


لقع رقع امع +كت3 

2اتمعم_عم. [ امع ]نت أصممر ككت 

بحت ععانام| “در ذكت 

لاركءاترعم_ع. رز اتع] “نصمتر مكت 

لارنا ترا لتزاعقصمص_ع.[ أضع] “أصممتر ‏ 353 

2 الا تواة مد لأععاما “معاء , لا مقت_ع.ز أدع] “أصممر 9كت 


053 
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بات 3]|_ع . |[ اتج] ,انج دلدت 

اتعرععدكم دام 

كاعاناشئعلط_ ١لظا_عاداش‏ "!1 تنام القت عتباددة 

انا | شل*اماح_ [لظا_عاداش"!1- إع دواد .[ الج 11 
(" صصح" )21 ناز" عمع لعذات” تج خصلم") 21 اتا رجاكا#انتمطك عؤادثتما 
عأ ععوما! تراز 

اددع 


5ت العاعث أضلمط اصع أحصاوامه عط اعم 
ععادانام تزجع ندم 
تنعت بتصاصط؛ اصع انددع داعم , عاعدع|ا اأحصد طمن[ أمت] “ندم 


ع5د نات ودتت] عطا اعم 
ع5دظع وتم[ اعلعدع|ا اأددد لطامت .| اقضع] نندت ندم 
اتح رع5 د عو دملاما دحلم 


302ل اتأعداك عط اعم 
302 تأععاك, اعلعدع! اددم كدت[ اتع] نندت “ددم 
“تت رعودله ]ا نتععزك نكمم 


أمعمتضوذات عاط عطا اعم 
أتتع متتو أاشعااع, “مدعا ددلامن.[ امع] نندت ددم 
“نحت ,كردا ااشمازع دنم 


أمعخاصضولات أععلاه اوعلطا عطا اعم 
ألف تف أاخضص معد , “عددع| ا ددلامن .[ أقع] نندت ددم 
“تت رحو أااشدعدك ندلم 


كلد أععدك أه اعطومبلكا عطا اعم 
دا ععك ان رعط سبال" مم كحدصناص| زعا[ امت | نندت عتعنخدمم 


بتع رععك لا لتربال"] دما 


15ادا]دع5 عطا أت عصتضضاوع8 عطا م[ دم 





لانات. 
251 
ناك 
اك 
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داناك. 
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اناك 
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لامك 
321 
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30 
23204 
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30 
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20 
3910 
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كاعناشطاط_ [آلظل_عاماشا"ا] أمععادرعصدم| لاد 
ععكم| رامع ندم 


#اعاناشعا]_لذانا] | ناعاط_طاحاشا"ا] “لام اكت عراباكدك 
#إناع رزاع زم 
ددع ادع نزم 
أدعدع ا 
تع جا دنا سنك عاد | “اعاصامط. |[ احح] 11 
#إتاعرع ه351 | أدامما 
حا تناح هام | عتصامط ,| امع | عنامت دنم 
لكوت 
اعاناشعنا_لكانا] [ نعد_عادام "!1 أمعدازة راعج لمك 
داع اما 
معدت تربلا - بزحاج الاصتا 
ععكم| رامع ندم 
#اعاناشعا]_لذانا] | ناعاط_طاماشا"![ "لام امت عرراباككك 
#زحاع زجاع تام 
علراع | عااحانث. 
ععطادة ٠ح‏ د نزناج [[, 
دادناسند ها أه عدزد عطا عمعدع دعل : 
2دناسة ؟ !ا نأمعاك, ز امع | زجع ندم 
و أااكعا ,دجت الاك 
تك رك 3 نا شاد اتأمعاك, [ امع ]| ندم 
“تدع رعع اد قبطم" عد لكا زاعع] ندمم 
ادع حا 
لكوت 
باعناشعلم]ا_لكات] ا ناعد_عاداثئ "1 أمعدزة راعج للد 
تداع اما 
لسارت 


مااع عط[ عنودد, 
عاإعاط عانصو دععدمات ععادثنما 
عاشعا_عانا بأقام “العلعترطاحط معد عا صضعمت ععادثمنما 
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نحت رعازعاط دمر قنك 

لذاآتاعظط_ع |1 ارلارنا رمعا عط عامادمع| إعامد عيادمنمز ‏ منيك 
طعادطا ندع ادوم تنك 

لارحزاتاناك أعة ]ام نجع رنعاكاما رعاتعطعا ع ما]علفا ععاصمئم] ‏ يمك 
لتك 

ا عا اعوما 1431 

عاإعاط عانصو دععدات) عيادمنم ‏ متك 

أ 3تك 

معنت وصا ع +«تدععظط_ أ ماد جنة 

334 4 34 34 34 34 34 34 34 34 34 34 34 30 34 34 34 34 34 34 34 34 34 34 34 34 34 34 37 34 34 34 34 37 34 34 37 34 | كنك 
51311 ددع 36تك 








- شرح شمرة البرنامج 


السطر 8 : نقوم بالحصول علي طول قطعة الشيل كود .. عن طريق طرح 
قيمة إزاحة نهاية الكود 2006]50!اع5آ51 من بدايته غ5131ع00-!!©١51.‏ 


السطر 11 : يقوم المترجم 41 باإعطاء خطأ عند استخدام المسجل 5) 
.. ولتهيئة استخدامه لابد وان نعطي للمترجم التوجيه: 


09 7لا 55م 
لان التوحية الافتراضي للمسجل هو : 


وهو الذي يعطي هذا الخطأ. 


املاع: 15 ع0الاد5م 
السطور 109-13 : تم استعراضها وشرحها تفصيلا من قبل في الجزء 
المتعلق بكتابة الشيل كود. 
السطور111- 120 : نقوم فيها بتشغيل البرنامج الأصلي المحقون به الكود 
السطر 111 : نقوم بالحصول علي عنوان النص 1365012اع1نا100/ااع". 
السطر 113 : نقوم بدفع عنوان النص إلي الاستاك. 


السطر 114 : نقوم بدفع عنوان مقبض الموديول 16706132 إلي الاستاك. 
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السطر 115 : نقوم باستدعاء دالة 061208001655 .. للحصول علي عنوان 
الدالة 61100101613001 الذي سيعود منها. 


السطر 116 : نقوم بتخزين عنوان الدالة 661100101613016 إذا إحتجنا إلي 
استخدامها في المستقبل. 


السطر 117 : نقوم بدفع القيمة | الالاا إلي الاستاك. 


السطر 118 : نقوم باستدعاء الدالة 016مج!اءان6610100.. وهذه الدالة تعود 
بقيمة هي هتزات مقيض _المؤذوول العالي للبرنامج :في الذاكرة.:وهذا العدواة 
هو بداية صيغة البرنامج التنفيذيةع8 المحمل في الذاكرة. 


والدالة 13001ا101ل000 لها معامل وحيد وهو ©310[ا101ل110م! وهو مؤشر 
لاسم الموديول المراد إرجاع مقبضه سواء كان غااع او اانا.. وإذا اردنا إرجاع 
مقبض الموديول الحالي فنمرر لها القيمة ا الالاا. 


عظا (مأآ عاتضقط عالاقصض ق كعصقلاع صمتتعصلة ع لاعترة لاع لسل مالللاع دا عدا 
30115 علا مأضا لعمموكمر صضععط كعقط عاآ عط 1 عالتمت نع أادعمة 
.55 8 دام تطاااقعء علطا أه عدومه 


أالترلة لاع انال ملاع ذا ع الا نان 1لا 
عصلقط عالاقمه ثه عدمعرللق ثر عمرت االع مانام 1511 )0 | 


امآ عادروط دمررااعم م1 ١‏ 





السطر 119 : بعد أن تم إرجاع مقبض الموديول الحالي للبرنامج في الذاكرة 
. فنذهب إلي هذا العنوان +[ إزاحة بمقدار 240 ] .. حيث قمنا بتخزين نقطة 
بداية البرنامج الأصلية 5/5015 عند الإزاحة 24 من بداية البرنامج وبحجم 4 


السطر 120 : نقوم بالقفز إلي نقطة بداية البرنامج الأصلية. 
السطر 162 : نقوم بالقفز إلي إحجراء بداية حقن الكود5131]_1116©110101. 


السطر 164 : نقوم بالقفز إلي الإجراء الخاص بمعالجة البرنامج الذي قمنا 
بحقن الكود به 50أ/اع/7١5]81]_196601.‏ 
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السطور 180 - 183 : إجراء باسم 5101/1156 خاص بعرض أي رسائل 
نصية ممررة إليه. 


السطر 186 : بداية إجراء حقن الكود. 
السطر 187: قمنا باستخدام دالة فتح الملف 0671516 وهي تشبه الدالة 
»ءادع في عملها .. إلا أن لها 3 معاملات فقط .. الأول وهو مسار واسم 
الغلف المراد فحة .. والناتى ذهو نس 689178101 تستقيل:بانات الملقة. 
والثالث يحدد الخصائص التي نعرفها.. وقمنا بفتحه للقراءة والكتابة. 

السطر 188 : نقل قيمة مقبض الملف إلي المتغيرة|أاط. 


السطور 193-189 : نختبر مقبض الملف .. ونظهر رسالة خطأ ونقفز إلى 
نهاية الإجراء إذا لم يتم فتح الملف بنجاح. 


السطور 195-194: نأتي بحجم الملف وننقله إلي المتغير5126). 
السطر 196 : نقوم بإضافة ال 512 بايت التي نريدها إلي حجم الملف. 


السطر 197 : ثم نقوم باستدعاء الدالة ©06٠|اثا0ا6‏ لتخصيص مساحة 
فارغة من الذاكرة بظول (حجمر الملك +512 بايت): 


السطر 198 : ونقوم بنقل العنوان المعاد إلي المتغير:©1م! والذي سيؤشر 
إلي بداية الملف في الذاكرة. 


السطور 201-199 : نريد هنا أن نعرف الموضع الذي سنضع به الكود 
المحقون في الذاكرة.. وبالتالي هذا الموضع سيساوي الآتي : 


عنوان بداية البرنامج في الذاكرة ‏ + حجم البرنامج + 1 
اج + ع5172] + «*«اهء ح()]] 


ونقوم بنقل عنوان هذا الموضع إلي المؤشراء[1017. 

السطر 202 : نقوم بقراءة الملف !]لط بطول ع5512 في العنوان (اعا/ام|. 
السطر 207 : نقوم بنقل عنوان بداية الملف في الذاكرة إلي المسجلاأل»ع. 
السطر 208 : نستفيد من التوجيه 35510176 في جعل المسجل أ0© يفترض 
أنه يتعامل مع بنية 51601871088 _ 6-5 ... وإلا سنضطر إلي استخدام 


الطريقة التقليدية التالية .قف التعاملمة الاناخات: 
588 


[301طط_ع] ما كأوامم زألع] 
[مامع_ع]| ما كأمامم [2+أ0ع] 


[الاعم13|ا_ع] ما كأمامم [36+ ألع] 
السطور 212-209 : نتحقق من توقيع الملف التنفيذي الذي يميزه عن اي 
نوع ملف اخر 


السطور 217-213 : نتحقق من التوقيع الذي سنتركه في الملف للدلالة 
علي أن تم حقنه من قبل أم لا.. التوقيع هو الحرفين " ]0ا"وسيكون عند 
الإزاحة [601+28] أي عند العنصر652)_ع. 


فإذا كان التوقيع موجودا .. فنظهر رسالة أنه تم حقن الملف مسبقا ونقفز إلي 
نهاية الإجراء. 


السطر 219 : نقوم بالحصول علي إزاحة بداية ال 58 من العنصر /ا©6306|_ء6 
ونضيفه إلي العنوان الحالي لبداية الملف في الذاكرةألع. 


السطر 220 : ننقل عنوان بداية ال 85 إلي مؤشر الأقسام ©عكم| 


لاستخدامه فيما بعد. 


السطر 221 : نستخدم التوحية 35510776 مرة أخري لجعل المسجل أ0ء6 
يؤشر علي بنية عممع نا 1/71_ع11186. 


السطور 226-222 : ونتحقق من صحة توقيع الملف. 


السطور 256-253 : بنية الأقسام عمد (ا_/17101ع1118625_58 تبدأ بعد 
بنية ا802ع1ا_1(م_ع 1186 .. وبالتالي لدينا المؤشر 566 والذي يشير 
حاليا لبداية البنية 58088 لا_11ا_111862 وبالتالي إذا أضفنا إليه حجم البنية 
8ع مع لا_1الل_ع 10186 فيصير لدينا عنوان بداية بنية الأقسام.. والذي ننقله 
إلي المسجل أ5© ونجعله يؤشر علي بنيةا8808لا_/(7101ع58_ع11186. 


السطور 266-259 : حلقة تكرارية يتم استخدام المسجل «<«ا»ء فيها كعداد 
لعدد الأقسام الموحجود بالملف .. الهدف من الحلقة هو معرفة رقم القسم 
الأخير في الملف .. ومن الممكن ألا يكون أخر قسم في الملف هو الأخير 
فعليا .. وبالتالي نختبر هنا العنصر 101631/10368 2010167 والذي يؤشر علي 
عنوان إزاحة بداية القسم في الملف .. فأعلي إزاحة هو بالتأكيد أخر قسم 
في الملف .. وبالتالي ننقل رقم القسم إلي المتغير©>©35]5 ا .. وللذهاب إلي 
القسم التالي داخل الحلقة التكرارية .. نقوم باضافة حجم البنية 

طم _/111865_581101 إلي المسجل أ5© الذي يشير للقسم الحالي. 
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السطور 269-268 : نقوم بإعادة المسجل أ5© ليشير إلي بداية أول قسم 
فيج اقلت 


السطور 303-02 : حلقة تكرارية الهدف منها الوصول إلي بيانات القكسم 
الاخير ©»©3515ا الذي حصلنا عليه من الحلقة السابقة. 


السطر 274 : نقوم بتغيير خصائص القسم إلي القيمة[01000000601] 


معممت5_الاعالا_للنه5_ع 6م11 
1 نا0عع_الاع الا_لاه5_ع6م 1 
مدعه_لاعالا_لن50_ع 6م11 
غ11ه/نا_الاعلا_لله5_عهم 1 


20)) ماه _[آلن_لالنك_غ6كم/»] 
00)) 6 _ا1_1/11141172لن_لال)ك_غ6م/ ]1 
00000000001 201121160 15 ]5واناع1 611313 اام 





السطور 279-276 : نقوم بعمل نقطة بداية 9/2801056إ6مع جديدة للبرنامج 
وهي تساوي (العنوان النسبي لمكان بداية أخر قسم + حجم القسم) .. 
وبذلك العنوان الناتج سيؤشر علي نهاية الملف ونقوم بنقل نقطة البداية 
الجديدة للمتغير ع/ثاعلاام! .. ونخزنها في العنصر 0156ه/9إ1أمع5501ع8001 بدلا 
من نقطة البداية الأصلية. 


السطور 285-282 : نضيف الحجم الإضافي 512 بايت إلي حجم القسم 
الحالي..لكلا من عنصري 0119311/10363ع512 و ع131512]األا. 


ومن الممكن هنا إضافة حجم الكود 0512 الذي نريد إضافته فقط إلي 
315172 ألا. 


السطور 296-290 : نقوم فيها بكتابة نقطة بداية البرنامجح 2 ]15[مطلإأمعا 
الأصلية إلي الاوفست رقم [248] في بنية 128081ا_111862_005 في 
بداية البرنامج.. حيث ننقل العنوان [ مغ + 10306835 ] والذي سيكون 
قيمة بطول 4 بايت .. نقوم بتخزين ال 2 بايت الأولي عند الإزاحة 24 والتي 
تقابل [0©1010_ع] .. ثم نقوم بعمل انتقال 515110100 .. ونخزن ال 2 بايت الثانية 
عند الإزاحة 26 والتي تقابل [0©101710_ع ]. 


السطر 297 : نقوم بوضع توقيع الإصابة بالكود المحقون وهو حرفي "0/1" 
عند الإزاحة [28] أو ما يقابلها [652)_م] 


00 


السطر 298 : نخرج من التكرار عند الوصول للقسم الأخير. 
السطر 301 : أو ننتقل للقسم التالي إذا لم يكن القسم الحالي هو الأخير. 


السطور 315-306 : نقوم فيها بنسخ الشيل كود للبلوك المحجوز في 
الذاكرة عتتضفاية الفلف ومن ثم حفظ الملف: 


السطر 306 : نقوم بنسخ عنوان بداية الشيل كود إلي مسجل المصدراوه. 


السطور 308-307 : نقوم بمعرفة العنوان الذي سيتم وضع الشيل كود به 
فئ_الذاكرة ‏ وهو تساوف (عنوات بذانة: الملف فقن الذاكزة +كهم العلف» 
ومن ثم نضع هذا العنوان في مسجل الهدف 01©. 


السطر 309 : نقوم بوضع طول الشيل كود في مسجل العداد “©6..وهذا 
الطول يمثل عدد مرات التكرار التي نريد القيام فيها بنقل بايت واحد من مؤشر 
مسجل المصدر [5© إلي مؤشر مسجل الهدف أ0ع. 


السطر 310 : يتم استخدام تعليمتي مع و 1701/50 حيت التعليمة 5/ا0] 
من تعليمات النصوص 55115705 , والتعليمة مع؛ تستخدم للتكرار .. وهي تعني 
[5عالإاط ,5150 ع/2701 ,أ3عمع١]‏ وتقوم بنقل البايتات من المصدر إلي الهدف 
وعدد البايتات يتحدد بالعداد)“#ا6ع. 


المتعحظر 313 ::زقوم بوظة مقتسر الملف على داق 


السطور 314-313 : نقوم بحساب طول الملف بالإضافة إلي الطول 
الاضافي 512 بابق ونع الحجمر الكلى الدتماتفق فى ا لفستجل يرده. 


السطر 315 : تم نقوم بكتابة الملف بدءا من عنوان الملف في الذاكرة 
وبطول المسجل“«اقع. 


السطور 324 - 434 : الإجراء 11110 51311_186©01/©6 هو نفس شفرة إجراء 
الإصابة ولكننا نستعيد الملف بصورة عكسية.. حيث نقوم بمسح القيم التي 
وضعناها ونعيد نقطة بداية البرنامج الأصلية إلي مكانها الطبيعي وكذلك نحذف 
الجزء الإضافي 512 بايت في نهاية الملف.. وذلك عن طريق تقليل متغير 
حجم الملف 5122].. وفي النهاية عند كتابة الملف نقوم بفتحه بالخاصية 
عغ287ه02_05 ليتم حذف المحتوي الأصلي وكتابة المحتوي الجديد بدون جزء 
الشيل كود الإضافي. 
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- المفهوه وكيقية الأطبيق 





يحدث فيض المخزن عندما تقوم بتخزين بيانات في متغير تم حجز وتحديد 
حجم له أصغر من حجم البيانات التي تقوم بتخزينها .. وبالتالي تفيض البيانات 
علي المكان التالي للمتغير في الذاكرة.. فمثلا إذا قمت بتعريف متغير بحجم 
0 بايت وقمت بتخزين قيمة بحجم 11 بايت به .. فسيفيض البايت الأخير .. 
ومن المؤكد أن يحدث خطأ في التنفيذ إذا كانت البايتات الفائضة بالحجم 
اللازم للكتابة علي عنوان الرجوع 212 في الاستاك وهنا سيشير عنوان 
التعليمة التالية 16] إلي عنوان خاطيء خارج نطاق مقطع الكود وستظهر 
الرسالة التالية .. 


عجزع . أونا 


ععماء ما ولععمه لوت سعلطممتة لععاديمعمع عقط عبع _أمط 
ععالاع الع اممعصرز عطا نغ بررمع عرح عببا 


نه وضكاردثه معت بحب ممتاخصصوص أضرعطا روصطاعمودع أده عاقفم عطا ص عرعبت بحب أ[ 
بأعصا عط أحاوامم 


لتعأطامع عنطا اماد اأمعموعراظ ااع١ا‏ ععدعان 


أقعر] الأب عمتا عب ما لضعع لقع بحب أخطا أرصمع ,ضرع ضة لمعامعع مقط عنبا 
لات لماز تدضة كقة أفنأضعك | أضصمع عق أر]ممع عاطا 


عإعنا اماع عصتقاضمع أتممع ,ديع علطا قأقك أقطت ععع د | 


ظ تدع 5 أمصدنا ظ أإصمع نا إصرع تمعد 


والفيض يحدث هنا لإنه لا يوجد إجراء “©3001 10]مع2<“0 لاصطياد هذا 
الخطأ ونقل التنفيذ إلي منطقة آمنة كما سنري فيما بعد. 


من هنا نري أن فيض المخزن عبارة عن خطأ برمجي .. ناتج من ترك المبرمج 
لمعالجة التأكد من حجم القيم التي يتم تخزينها .. وهو منتشر بصورة كبيرة 
في لغتي ++0,)6 لإن بها مجموعة كبيرة من دوال التعامل مع البيانات 

معرضة أن يحدث بها فيض .. وسنتعرض تلك الدوال جميعها في نهاية الفصل. 


وعندما يحدث فيض المخزنف 01/6/10 /ع]آلا8 نستطيع التحكم في سير 
البرنامج وتنفيذ التعليمات التي نريدها. 





والمخزن اع]آنا8 هو عبارة عن مساحة في الذاكرة يتم حجزها بحجحم محدد. 
ومن الممكن أن يكون المخزن في المكدسا5686 أو الكومة م63ل]. 
503 





ولك تتعوق على كلا الأنتين ,د افللقى تقلرة علي .ذاكزة الترتاقة عندما قمر 
تحميله في الذاكرة وتشغيله .. 


15 الاما 





15 لوالا 


عندما يتم تحميل البرنامج في الذاكرة يتم تقسيمه إلي ثلاث مناطق في 
الذاكرة علي الأقل يطلق علي تلك المناطق الاسم مقاطع 2 كألع5600 .. 
مقفله الكود ومقطع الندادات :ومقطع. الفكدتس: والكوفة ٠:‏ 


مقطع الكود ع1 به تعليمات البرنامج .. بينما مقطع البيانات به جميع البيانات 
المعيئة والغير مهياة. 
ويوجد مقطع مشترك للمكدس والكومة يتم تحديده في وقت التشغيل .. 


المكدس 58321 يتم استخدامه للتخزين المؤقت لكلا مما يأتي: 


1 - معاملات الدوالك 5إعأع60ة23 0م10نأ0 انال . 

2 - عنوان الرجوع 2800155 الالاأع؟] عند استدعاء ا|ا3) إجراء. 
3 - قيمة الرجوع عناا3/ا الاأعض]. 

4 - المتغيرات الداخلية 3161301©5//ا .٠0631|‏ 


الكومة مهجع!! يتم استخدامها لتخزين كلا من الأتي: 


1 - المغيرات العامة 311301©5/ |6103 التي تظل موحودة من بداية 
البرنامج لنهايته. 

2 - المتغيرات التابتة 31130|©5/ا 51311. 

3 - تحديد الذاكرة 41063600 /ا001ع11 عن طريق دوالك متل الدالة 
314110 .. يتم هذا التحديد في الكومة. 
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الآن يجب تحميل برنامج ++© لا©1 وهو عبارة عن 1008 ممتاز للغة ++0 .. 
ويمكن تحميلة من موقع : 
/بأعس . 0ع 0005 لط . ننالانانانا// :صخاط 01 أعم.ع0ماع6ن50// :ملاح 


بعد تحميله وتثبيته وتشغيله ستجد الواجهة الرئيسية له كالتالي .. 


لساك 72 +ب+ح ع0 "” 
كنا خأامه ]ا وبطعنا عالععبع إاععمصة ‏ سعثة طعرمعك ‏ الع عاط 
ماع ل بخاحوصانباي؟ 


> اها 3 © : كد ا هك كه 3 خخ (88 © لها ل © لها : 
عاووه] |9 العم | لك معلا | | د لت َ 37 1 ] 05 


ب 


وسطع ن] | قعهوةانا ِ عردم 


: 1ك 
عية| ْ د ]لاصعع 8 قا مانا نإل 





من قائمة ©!1!1 نختار ام6ع(0ظ نع لم 


2 ملح بحم 7 
كنا #اصضهت |[ وبطعنا عالمعبع اععمة ‏ سعكة طعمعذد الع (اعاط 


ااانا اا عدياصدك ا تبات أذ ظ 


ال .عالط م أععرم مصعملا 
عا عاط عع معع م 2 لح تنما و 








وستظهر النافذة التالية الخاصة بخيارات المشروع الجديد ونحدد الآتي : 
1 - نختار نوع المشروع 163]100امم8 ©201501). 


2 - نحدد اسم المشروع وليكن"801". 
3 - نختار لغة المشروع ++)2). 
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4 - نجعلها اللغة الافتراضية للمشاريع القادمة. 
5 - تم نضغط»ا0. 


| خم أععزممم بعل" 
ٌْ 1ق 8 | 


 ُِ 92‏ © © خا 


اصعرم 0 باموورع اانا لإق طلا اكاك عامقصمنا ل باب 
تاداأقت اممثت تدا ]قن اممم 


دام ممع نا 
إشادكصات كلاناكك؟ا]| صداقد اممة عادعصصص م 


:داامه أععرممة 
6 أععرم عن | 1 أععرم ا ا :312ل" 
8دناوصة ا االداعنا عكاد اا | ني ١‏ لاع 


ظ ماعنا 7 ظ اععدةن)ا 3# ُ 


بعد الضغط علي 01 تظهر نافذة لحفظ المشروع فنقوم بحفظه في مجلد 
باسم "801" مثلا علي دريف السي "0:1805".. ونلاحظ بعد الحفظ ظهور 
نافذة” بالعنوان "0315.600" بها كود افتراضي لتطبيق ©01501) نقوم بحذف 
الكود الموحود ونضع بدلا منه الكود التالي : 





ٍ ممت .حراقهم [*] 


11 . 23 1 1غ 5 11103125 :111 # 


([]1 23 52” 21153 ,تت 31ت 11311111311 1111 
1 
م [5 ]| اعت 131لت 
111111111111111 ل "11 "!1 لظ 88181121-12-1111 لاشششة" - []112اط 1ظقلات 
اط +522 امامت 3512 
لا 12111111 
ا 
اسم الملف الذي نقوم بوضع الكود به هو 031 بالامتداد م60 اختصارا ل © 
5اام 5لاام .. هذا الملف لم يتم حفظه بعد وبالتالي من قائمة »!1 نختار ©/531 
أو قن عريظ ل كرات تقار ا قونة الشقط ذفن لمر طون سنن الحقط:. 
فنحفظ الملف في نفس المجلد "0:80" 
لترحمة المشروع الحالي وتحويلة إلي لاع نضغط علي 9 اف قث قائمة 
عألمعاع نختار "لاا © ©11 مام .. 
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نمضتت تثبنا #اصضت] وبطعنا (اعابععدع | أاععرمط 


عجانانا عاأمممن عع - لصل 
9 +ااا+]ااطاك عا أصعويت ع|امووما ل | ا 
10 عجانانا ضع [] 

ْ ...أ عأعمرقردم 1 

ظ عت .تزاككم 

]| وع ممع غ عاأمومن إلا : 
11 ع+اننا اث ل اناطع 

ا تاععطنا #قاصبيك 


ونلاحظ عند تشغيل البرنامج ظهور رسالة خطأ ويتم إغلاق البرنامج .. وفيما 
يلي شرح للكود الذي قمنا بكتابته.. 








خط. وضوعغع5> #41211104 
نقوم بتضمين الملف "5]110.5اع1100١مم)-/اع110:)"‏ وهو يحتوي علي 
إحراءات للتعامل مع النصوص ومنها الإحراء لإ5]]60 الخاص بنسخ نص من 
متغير لاخر. 


([ ]اوعد > تتقطة:. رجت 1 337 116 
٠‏ 


الإجراء 031 هو إجراء بداية البرنامج وله معاملين 5إعأع 330 يحددان 
الوسائط الممررة 410101755 235560 عند تشغيل الملف التنفيذي .. ومن 
الممكن ان تضع لهما اي اسم وهما هنا ©3106 و/301017 .. 


الأول وهو المعامل 3102 أو (](الامء 017616ا310) ونوعه 116061 عددي بحجم 
4 بايت وهو يحمل عدد الوسائط الممررة للملف التنفيذي. 


التاني /ا310 وهو عبارة عن مؤشر إلي مصفوقة حدودها كالتالي : 

[3/01/]0 يشير إلي نص به المسار والاسم أو الاسم فقط للملف التنفيذي 
حسب طريقة كتابة اسم الملف لتشغيله. 

[3001/]1 : يشير إلي نص به أول وسيط ممرر للملف التنفيذي. 

[310112 : يشير إلي نص به ثاني وسيط ممرر للملف التنفيذي وهكذا. 
فمثلا إذا تم تشغيل الملف التنفيذي من05اا أو 6110© علي هذا النحو : 
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عياع . ل دمعا2 3 دمع دوعا 5 ا[ ناذا للا؟: ) ١ه‏ 


الح م 






را ركس اسن 9 1 كن ا : لحن 1 : اكيش 





3 - 3106 
"عماع. 802" - [0]/ا0ا3 
"والراو اط" - [3101/]1 


3101/]2[ - "60001410" 


5# معة قمع 


نقوم بالإعلان عن متغير مصفوفة من الحروف 03136605 بطول 5 بايت أي 
كل حرف بحجم بايت. 


ونلاحظ أن طريقة الإعلان عن المتغير:أ5 تتم علي الاستاك .. 
17 5] قةة متقجاع 


م "850000010101010 8 2 لش لش ثلث ٠" ١‏ "2 لط بط بط :850000101010108 ضاق قز ثق قث ثم  "‏ - [ ] 1 باط عقخطه 


نقوم بالإعلان عن متغير مصفوفة من الحروقف بطول يتم تحديده من النص 


المخزن بها وهو 40 بايت. 
وسنستخدم هذا النص بهذا الشكل لعمل فيض في مكان ذاكرة المتغير ]5 
في الاستاك. 


اط 1م86 8 


نقوم باستخدام الإحراء لإ56:0 لنسخ قيمة المتغير 6لاط إلي (50.. ونلاحظ 
مشكلة هذا الإجراء انه لا يحدد الطول المطلوب نسخه .. ولهذا يؤدي لحدوث 
فيض عند أأ5. 


+0 ط2تاععع2 


تستخدم لاع لإنهاء الإجراء 17317 وبالتالي عند إنهاء الإجراء الرئيسي 
سيؤدي إلي إنهاء البرنامج .. وتتطلب 107لاأ©] أن يتبعها كود رقمي يشير إلي 
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الفصم 5 





طريقة إنهاء الإجراء .. 
أي مشاكل أو أخطاء حدئت في الإجحراء م اقفة 0 الموجود فعليا. 


الآن عند تشغيل البرنامج تظهر الرسالة التالية 





عجزع . أودا 


عجعماء ما ولععه لوه وعاطممرت لعمعادسمععع عقط عببرع _أمطا 
لمع لقع «ممعصر عطا مغ بررمع عرح عبيا 


كله وضكامه معت بحب صد1اخصصص اضر عط _روصطاع حصدع أده عاقوام عط ضر عرعس بحب | 
عدا عط أحاواتم 


.كتعاأطدمح قن”طا انامطة المعموعراظ لاع ععودعان 


أقع] الله عن وبا ما قصضعة فقع بحب أقط أر[صمعر أميع قة لعامعع مقط عيبا 
لاك تم الصدصة لصة اخناضعل1أضدع عق أرممع عاطا 


لاقاضمع أر[صمع,) ,ديع عالطا قاقل أقطات ععع ه | 


عمدع . أونا 


ع الاأخضواع مررع 
حبص ضعاضب تعحرة نافد اما مصث ععت أحط :عو لفاممم 


121211012 0 لا.نا.نا .نا توع هاما 


اكاك نا مص ممعم 


عط تلع بععه معاطمم عط معطت ععع أصط أه صدء]أقصمع عط وصاكءقوع صدئة ص صاصر تععلفساعمر أرصمعر رصروع علط 1 
مععب عط لابدكع طعتطت ,ناا أعتصط افتتوانا ندب زععب صر عرةسضلمقط عتمملددت لصة صدرعرعتب معاعبع ودرادعمه 
عامصصفت بصب له عععرللة ره اا] أمعمتمط أعصعتصضا عط قصة تععصعصر| ندب منأتصعكر ما 


بااةصدععمح أت رتغ بعطله نيضة عد ععع كه القحمع بععع ه53 رعدمقه ععالة ربصب أععاادع بالاخصصحتصعغصا أصص حك ع'بب؟ 
عه حاعية صماءة دم حآضا عل اجععمع- ع رممتعبيه ماقتضدت تايمح ارصم رصريع عط يعمنعست احا .ضمتخ ص ص]اصضا عاطذ] لتصعك 
]ا بالاصعك)] بحب عصاممرعيعك دم تجعب عط الك اتضعندجم كاأبدجع صملتخصص صلصضا عاط عالظمم؟ .ععال صعمه نمممئ] كأككت 
تجهعب عط أصص لالت عا أصعععم 


اها اانه عت رعاطة الف حكة عا صدآخوصلضا عرصم ]| .معاطدصح عط عل ما مععب عط بناضصد لالب ععطاامع عن أحط؛ كنادك عط 1 
عدخطة ]3ك ذخ ما فد ]أععصصمه عابععة كت وصاعب أضعة عط الله غرصمع رصع علط | .تمعاطممع عطئ أرحمعم بصب معطت بصب 
عع ةممابم مطائع ارقم ردخ تمععب عط نتصص اللس خضة ععععدة لمعناحملا طغرب 


ععط غاعاجت أرصمع رصريك عذا أبصطة ممتخصص]اضر اخعصطعه؟ عع صل 
معط عاعجت طعت عطا صه معناصم صصاعع|اصح كادلك ابه عمعع م[ 





وبها نجد أن تم الكتابة علي عنوان 218 حيث العنوان الذي يتم تنفيذه حاليا 
هو [42424242] أي [8888] وهو الذي أدي إلي حدوث هذا الخطأ.. 
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وبالتالي الحجم اللازم للكتابة علي مسجل212 في الاستاك هوه 32 بايت 
ممممعع »88882 ممم مع ععععععممممعع©886 8 8 4424م 


نقوم الآن بفتح الملف "©<«©.601" في برنامج 06509961 لإاا0 لاستكشاف ما 
حدث فعليا.. ونضع نقطة توقف عن سطر استدعاء الإجراء لإم5]1 


[أقط غانال هته ,لقعىطاا دتهمم - لاتاغ ]| - عهاع . أمط - عدا ناجاا0) 
ماعط كشد3من كعصدتاصكتف جدعة/]1 ولطعن سبعلذ عالط لعا 


ع لسك لهاع ام اله نااك نانك لاك > |44 ها 


[19 . الانانالا] م 1لاع » اأإناعك 1 ضكنات 
لان امم " الى “7 موعععمممم»” 0511 مخضت مناه , #مط [طأدع 2ن , 1 5ع 2 5 . 2 
اع 


م 9 بع 0868 3ع 
اناك ع يا :كنا طلم ع[الئط ,[ 1ناع ا تمع ززع عرالع علارام 4م :دع عء 
اعع23ههم : [13 . انناناا] مومع 2 ك415ننت  ٠‏ [إناناح 1 خضلكضاتم 
> إععخدوم 1 #ألع , [24 . _ادتانا] :52 طرع بابطنالبانا 243 +4ح44وده ‏ ٠ع‏ إاأعنات [تطجمك 
0 التإدوعع53 . الانالالا] “م #وقرع 8ع 45لا 5‏ ع |0تلات [1طجتم 
“11 1 تاق #مع , 1كت . اعناناناا :55 رع نانانالبان] انالا 5 0 ٠‏ إإذلات 1تاكتم 
دحيم دع منريل باحص 2ت , احزدباكنية , "ال > _االانا | تاققضطتضصعك عع 2.ء 
12 تاك ناما قم تمع لانالا ا 0 


اتانالاا] ,3ع ناعا 
1ع 


كلاذ 31 2 نتمم 


عا ثانا ثاثا 
ثانا تاثا 
ثاثا ثاثا 


2 عع 0 313 ع عع عع 
05 ]6825 062205 : 0 98 هوا 


العسبدص] | عالاتدهر ضاقمم أت 0 55 


ثم نقوم بالضغط علي 59 لتشغيل البرنامج وسيعمل حتي يصل لنقطة 
التوقف كما في الصورة التالية : 
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5 [193 . الاتنانالا] م 1لاع 2 للاملات  ١‏ إأناعت 1[تجنيات 
هه ااتعا نات ناك نات , بصط [عدع الا , 1 دئ5ع اك اتات عع ٠.‏ إإععت [ تنكمت 
ضع عات ناما 
دعم عد دح قتاع اتات تاتافدع دع ٠.2‏ [إطنات 1[ تاكتاك 
مم كم ممه ع ]نغ , [ [1لاع ]تدع ززع ع رماع طارانم جنر ماع ٠١‏ (إلنانات 1[ ىتات 
متعع5-ت مم [19 . انانانالا] ممع 2 ط5ك4لا]كت  ٠١‏ [أإناناك 1[ جنات 
دعع22-5 مم > #تلاع,[4ت . انائانالا] :55 ررم ]ا لالران خم ج2944 ٠.‏ [إعانات 1[ تتام 
دمت نمم ل . انا خانالا] م ممع نم 2ع طكلات  ١-١٠‏ |1اتلات 1تلكنات 
دعع عيرم #لاع ,لطت ._الانالا] ثُُ 8زم ]ل لبان جخ41تمد دك ٠١‏ [إ[إكضلات [تطكتاك 
احرج 5 , اتزصيك وي . اال > لانانا | تكضمقضطكطضعك 8ع 2اء 
دراك 1 كناكم ع م #ونبرع انالا | تطتتضضصصضضيتك دع ٠‏ [|إعلات [ضجضمتك 
2ه جع 3 . انانالالا] 0 ناع ا . 


01م ذا 
ناما 5د 
تلطه ذلا 
عحمه دع 
ثاثاطته ددا 


اندع +32 ا 12810 هق 


ة 02 اتام مسا| مر :3222نم 
كح اتات رك خات 
0 اتات تا4تات 


ماك ناك نات 


ل 77. #عصبهم مع 8كفمقممم , عمصبهم ممع للعلااعم أسجبة |2ع10202مم 0 


مله إهامزة ]كرك 





ثم نقوم بالضغط علي 8 لتنفيذ إجراء لإ5]160 بدون تتبع تنفيذه..لينتقل 
التنفيذ إلي السطر التالي.. 


ا ار تاك رليرت لياش سوا ادل طلالف 


0 
3 .-08ا0ا] , 881 70ت 

0 848 . عمط 022587 , 51 86284886 غ8 
3 


سد _- باع 868 89 

> :كم هرم عمق ,1 1لعع ودع _عرم عااعق كلاللا 4 

المدعهععقودوم 1زعدم 2025625 7 1 اا 0 

3 ع , 243 .انان ] :55 218 (اغاناللان 4 394424 
9 . غم 88483823 

دما ل - الانالا!] ,#اناع 8_ 8045 

, 25 . الانانناع :5ك 818 (انانالبان اناا 0000 

عانات 1 فجقاظ , #صط طناك 1 ونام 0 0 فافاقاض كفك 3ع 


لاع لان | ممتتضضضهم دع 
كد رععع عع صصح بق +8 طعت 5 , 
عع عع عع 1ه 
لع عع عع 81 
ححا 1 تاها انا م 


0000" ال د 
""لالانانا ان عع ممممعععععع عع نانانانان اتاناععععمممم؟"" 11نكق زء 


461287قق , عمط مغ 1738قكقه , عمط ممع للسلللاع8 | . 





ونلاحظ هنا في نافذة الاستاك حدوث عملية النسخ ونتايع الضغط علي 58 





الفيضان. 
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زأقط غعانال هك ,رلهع :اا دتهمم - لاثاغ | - ععاة. أمط - وانابجاا0 
ماع كعشاملمائ كمدلامت عع1]3 وراطعن سعد عاط زعا 


لكلا اللا الا لقلا اللااكاا. لك 1 نط انك انلاح اع |6 4 اك 


ٍ ثانات 1 تطكتاته _ اانا | قت 1م14 دع مات 1 تلك اتا 
لاع | جرع ع ع ) جعع عا 2 لأتملات 


ممع عع ععععع”"” 11ناكم 


نمطم ممممم”"”_ 5211م 


وا نات ناك تاثا . #صطا 


ضعت 1 تالجتا , #صط 


(عععععصعع اه عاطعة 
عع عع ]ها +]طتك 
2222281 أله +]طتك 
[عا8 2ع 1ه +]طئك 


نات ناتاثاتاتا 
اطع اتا 
نااك ناثاتا 
نا ثانا ك نا مانا 
نام ع اتا 
تمع ‏ نان 
لح نات اناك ناا 
وطع عت عنانا 


عت 1 نكتان " 


ععع اممصضطن]اعع”م لف 


دلاطع ) كجرع 3 ] 


أمععمممم عععع” 11ناكم 


انان امطع طم ممم" 11ن1اكم 


معت 1 مك ياتا , #صط 


ناخانا ناما نامم 
اطع اتناك 
تاضدع د تنا 
نانك نا امات 
جم ددمت 
تمع عنام 
طشخطكدك دك 
وطععددومك 


معت 1 نوات 


لععع عع عطع]ع الم ]ك3 3 


(عععع غ822 ]1ه #] طم 
غ822 ]1ه ]طم 
( ع2 1ه +] طم 
( عط افافو ناعم +1 طقة 


الالال كا 
89 |1 طع_طناطاناع عتنامضاتضمم 


مسرو مسر 5 1 1 


لكر عر نز عسو اا لكا لكا لكا 


101 لكان لانا 


ع8 


ل لاون كاتا 


1393 . الانالاا] م 1لاع م 


قات جات , #دط [عدع ذا , 1د5ع 
2 كماع 


:كنا 218 عالنا8 ,ا الاأعاتطع قاع عزالاع كلانان 


12 . الانالاا] ,تامع 
فنع ,341 . _انناناا] :55 طلم لاانالبانا 
ل . الانالاا] مذتضع 
قناع , 351 . _اتاناناا] :55 8م لاأناابانا 


لامع 6ت , ا زعبكوة ,اال لاننا 


اثا م ثفمطع 
[3. الاناللا] مدع 


455454 


93 . الانانالا] م 1لاع 
تاقح م ىقال , خصط [عدععنا , ادع 


- اوناع 
داوعلا طاي عالئع ,ل الأعاتعع زع عرعمع عبان 
و 192 .ان ةالالا] ممع 
كمع ,341 . _انتاناا] 55 طرع لاإعناليانا 
ل . الاناللا] م#«لرع 

#لاع , [25 . اننانا|ا] :55 برع ]ال ليان 
بصع 2ت , #عزصبك وي . الال > اانا 

ض مومع لانانا 


[ل3. الناناناا] ,ادع 
51 


لكان 
ناعا 


عا 
| 


ات مك مات مات ع8 
اع 


ثانا قاض فاتقادات دوع 
خم مدع 

_ك45لاة 

ذنم +جح4دجوع 
8 _ك5ك4لاة 
ات 

ثانا ماما تاك دع 
ثانا ثانا ناثاثات_ 85 


لاملات 
تإخافاك تاد تاه عع 


ا 

تتاف عقصصدع جم 
04 :ع8 

655 _ ك5كلات 

4ه _جدتججوق 
8ع _ك5دلاة 
مده 


تاتاقضطمعك دع 
تتام عقص مضه 5م 


218 1 فاه 
امات 1 ثالك ماما 
نات 1 جام 
لات 1 تلقام 
خذناك 1 تممم 


غنات 1 تامام 
2ع2 1 تامام 


ضعت 1 ناكام 


غناك 1 كات 
2 1 نك نات 
ضعت 1 كناك 
معت ل عخمت 
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انانانائعععع ممم" 1 1 ناكم 


5 التانانانماعععمممم؟"" 1 اناكم 


2ك 1 ناكتات , #صطا 


زعععععععع به 
زععع عع عع ]8 
ععع عع ععع ]ها 
زعععع 818222 


زععع عضت طن طاطم 


#اطكك 
#اطحعة 
#اأطعة 
#اططاحك 


نان ناناتام لمكم 


اط © لالط 5ن 


مامح د تانانا 
نان ناك نامكم 
8م ع ادن اتا 
دم ع ادك ياتا 
5كطكككدك 
ذظ5454 ك5 ل 


128 مق 
3 دع 


+*اأطكتت ١‏ 
الالال تر 


و !1 !ل اناكاذاع اتات تامام 


الانانان اتن ناتاعطط8"” 11 ناكم 


وعت 1 تالىتات , +صط 


عع عععععع اه 
عع عع ]ع ]ها 
عع ع عع عع ها 
عع ع 0غغغ2 ]8 


نعطاع توصت نا طاطم 


]ك3 
#اطح3ك 
#اطكعة 
]ناك 
]طعت 

الالال 


ات تتا ثاخات نات 


خاتاتانا تامهم 
ناك ]تلم 
تاتاات دتانانا 
تاكتك نرتركرم 
نامرع عدت لمات 
1 12+13 
كخطكككدك 
خكةك4 515 لك 
دعت 1 كمض 
2ك اناا 

1 نات 
اتا 5 
الم ١‏ 
نات 
تاثا 


ارا مسر يخ هسم ليا نكا لا الا 


ار عسر إن سم ليا نكا لا الا 


ال لا اعت الاش ل تبسر 2 درل نالف 
ماع كعسضصلمنك كمدعصتف ععتقع] ونرطعن سبعت؛ عاع إعا 


اللا لقلا للا للا اكلا اللا للا 1ت 11 ند اك انع 111 اع اع كا 4ه اس 


اناك 1 تاجتاض_ _اانانا 
[19 . النالالا] ,1لاع قا 
ماقت قضكتقت , #صط ادع ]انا , 1 5ع 


- اح رباع 
داوكنم طزرع عالمئع ,1 1لاع ] مجع طرزع عرقع جبامم 
32 [(12 . انانالالا] مث تلمع 
#ألع , [34 . _ تاتالا ] 00 مم ]ليان 
.الانانالا] ,ةنع 
#لاع ,م [35 ,. _الانالا ] ١‏ عمزم ]ال ليان 

لامع ص2 1ت ل اتزص كمي .طلال > لاما 

ضام ورمع لانالا 

[3. الانانالا] مضع نع ا 

[دع م 


111+ 
حكن دحل نك 
53434+ تك 
كك4كك كك كك 

. المحم د نمم 
التاعتاك امم 
نا نمت 


اناك 1تمخقتض_ اننا 
123 .الانالالا] ,1لاع قا 
خاتقات مهلقنت , غصط ادع ]انا , 1 5ع 


9 رباع 
:5لا 218 عاق ,ل 1ناع] مجع ززع عرسم “انام 
192 . اناناللا] م ثتلرع 
#تمع ,41ت . اعتاناا] :55 بطرم 4الالبانا 
. الاتاللا] م تلع 
تمع ,51ت . اضناناا] :52 بطرم نال لبان 

ارت نز 51 , #حرعباك ودية . ال > _لات ا 

قا تمع ارال 

31 اننانالا] مضع ونع | 

[جع م 


4 4ق 
43434343 
4444 4فجة 
. | كك 2ك همي 
. أ كك 4م جومم 
5 الجمع دتمم 


ثاتاصك 1 فك 1 _دع 
08 لاثلاك 

ثاخاض 4ك مدت عام 
اع 

خام م ضممدت دم 
ميدع 

68 ك45لات 

4ه _+جدجوودع 
8ع _كدنات 
يت 


تامع طكم مك دع 
اخات ات ناتاتات_ دع 


ماقت 1 تك 1 _دع 
02 لاملاك 

قات ك مدنت عام 
2 

عم ممدت دم 
جم مدع 

62 ك45نات 

4م 4ت 4ددع 
8 _كدلات 

ا يات 


لمات مكم مك دع 
مانانا مانا ثاناتا_ 85 


ماعك 1 نكتانا 


12101 4ه 
غناك 1 جومم 
نات 1 تك نات 
ذلات 1 تمك 


عت 1 ناك نات 
نانك 1 ناك نات 
اعت 1 كام 
كنات 1 ناك ياتا 
كناك 1 نكمم 
نات 1 نك تائم 
نات 1 اناك ياتا 
اناك 1 ناك نام 
كنات 1 نك ناما 
ضلات 1 مخمكم 


علات 1 نك نام 
دعت 1 ناك ناكا 
ضعت 1 ناك نات 
م عاك 1 ناك ماتيا 
دعت 1 كمه 
دعت 1 تك ماك 
معت 1 نكمم 
ضعت 1 نك مام 
ناعات 1 ناك ياتا 


تاتاتاك ناك ناا 
1 تاك ناك تا 
فاك تاك ناك انا 
تاحتاك ناك ناكا 
كنات ناك تان 





ثم يصل التنفيذ لتعليمة اللأعغا والتي تقوم باسترجاع القيمة الحالية من 
الاستاك والتي كانت من المفروض أن تكون عنوان العودة الصحيح (النأعك] 
5 .. لكن بعد حدوث عملية الفيضان تم الكتابة عليه واصبح عنوان 
العودة حاليا في الاستاك هو [42424242] كما هو موضح في الصورة السابقة 
والتالية. 
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اسه رللنة كلل -1 15 > ورانار ان 


تا اتات تاتامته ومع 
باط ات عطاك تناع 
امت اناك لاع 
اناك ثامامكه ومع 
""لانانالادانانانا"" 11 ناكم قعععدعضت طوع 
1 تلع 
45445 5ك ا 


م لمك 1ع 


لد رعمععع ]0099060 لطت 23 ع 
زعع عع عع ععطال #إطمدت 5 
زعععع عع عطاقت #أطمت 55 
عع عع عع عع]اته #إاطمت ذدت ا 

اععع امطمض ع ناععكم 8اطتك 2 
الالال تا 


3ن انا 
اا عر ةا عم ةا لكا احا نذا 


3 ا ل تا فاخا نا خاماتا 


11-4 





كل ما نريد عمله هو إلحاق الشيل كود لدينا ضمن متغير ]لاط وجعل عنوان 
8 بدلا أن يكون [42424242] يصبح مؤشر علي هذا الكود.. لينتقل لتنفيذه. 


سنقوم بتغيير الكود إلي التالي بعد إضافة الشيل كود : 


د حل كتنناعصاسنت ععبراعنرع 
حاطل إعدباضانةت عمبناعنرع 
خط وصاذكدت ععباءد# 


بقعدلة أ كصضآئلط اط عالكات | كل]1!) ددا كاصابتا [درت نبا ادر 
ب صحاطة عض [ متم عاط ع_الذات | 5كل1نا 
أتلع اناو )شدوم| 8[ 5ص | 
(الأطعصحخصبينعة انرا 


بم ز.] نا طلم لا اكلا [- لذلا للا 


1 
ا[كاناه دطء 


بم 
نا 
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الفصم 5 


اد إص منص ما كصارع ع رم 


[تصلاط 3] ددع دلقم أرواط ع رم 
لاق نركم لنولالر رك 
عاتصحط_تطاعك اأهه ,م 
ترطع ممم :عاتددطا_تااعل ,م 
عاتصخط_دطاعك أعذ1اآم تناع داباك ,م 
[ودم_+ ترطع ]عع هما مر 
نا تأكلاتز رم 
67 اأكلال مر 
عع لأكلاتلز مر 
لا تأكلالز رم 
415141 نالا ]: 15 211 بلبالالازانا أأهه ,م 
كئزمتمعودددع |" أأدنا <-- ,رم 
زد ناناكل4نانا]: 5 2114 نل؟الالالانا أأهه مم 
دععم ]ابرع أأهنا <-- مم 
لا نا طال ودذرم_ مم 


- [[إآأباط دكات 
ال ل 0 
"لكبو أل لبو ربوا ل طبر عبار عب رادي ري 
"كبوأ لبو ربوا طبر عبار عب رادي ردي 


ال 0 


"لالاكن أ باع عير رمي" 

0 
"لازأ الات انأل لامع" 
"مكبر" 

الست سات إلا 0 
"انامز أنالكي أ 1 عمو ابام" 
"انامز تمي" 

"517 

517 

"لالامز ضمي 

"لاعت أ ناتعن 1 طبرا ب كبام" 


"لازأ رلك راك اك با 
"لالامتأض تبر اا ا 


الأناط ,قاع مداه 
لا تاالااع”م 


/ 


(دأدثت ددا دادب 
1 


لام ااام لكام اال لكام االنالةلائئ«مطعوددودعم' 


عشر مثل "0" في الاسمبلي. 


القيمة "907" هي التعليمة [70] في الاسمبلي .. وهذه التعليمة لا تقوم 
بفعل اي شيء [06]!3]100 50] .. فقط يتم تنفيذها وينتقل التنفيذ للسطر 


105 


/ 








التالي .. وبدلا من أن نستخدم نص محدد لكي يحدث الفيض .. قمنا 
باستخدام 28 بايت من التعليه ‏ ابإنارل 
بعد 28 بايبت : 


العدد اف سدانة التعدل كذ وحن و 0002362501 1" أن كافة العناوين 
تكتب في الصيغة 116-600130| .. ولمعرفة ما هي؟ ولماذا؟ يمكنك النظر 


لصفحة [195] من فصل برمجة الشبكات. 


بعد أن حددنا نقطة بداية الشيل كود سينتقل التنفيذد »© إلي الشيل كود 
ويقوم بتنفيذه .. وهو كود تعودنا عليه لإظهار رسالة نصية ومن ثم إغلاق 
البرنامح. 


فقط في بداية الشيل كود لابد من تغيير عنوان الاستاك الحالي ‏ مهو إلي 
عنوان بداية الشيل كود في الاستاك .. وعنوان بداية الشيل كود يتم تخزينه 
في المسجل “اع في هذا المثال عند حدوث الفيض. 


والصورة التالية توضح الشيل كود قبل بدء التنفيذ. 


3 لساك [لمعدط1 متهم - نامع ] - عع ]80 - عطهبراا0 
ماع 5شاململكذ كمصمعصاعمتة جعة1 ولاطعنا سبع عع لعا 


دلا 1 الال لط لك اناا ادنك الساعاع اناك 


زلاع)_قصعغةوع5 لاع , 5ع لبالاذا 2304 
0-2 88236287 _ لام | 8همهممهة 3ع 
0 ممح تلام 0 
8ع ام ان غات 1 تك ,ممع علات ١‏ فكت 1ت لاع1اةت 
م ا 1 ناك . عأنام+ صمع ] ,تناع نع | | ققم 4ت 1دت لاتالات 
ك2 انا م اذل ناذا لاخ 
فد مد مدت مع 3 26 انها 
ل | م 2 022 


1 اا 5 8 لاع 

لاص يه ه8عوةدعه1] . 5832 5لاء8 ] :05 818 لاعلالبانا 215 
88 86231 امعد ا باع . 32 الدع كاءة > ] :05 218 لاباناليانا 4 2215 |8لا2 60222 
55نم عد 02 86222205 
١ 0‏ 86227 
0 1 خلا 46 80222202 
ل : : 862220 
8638 
0 





ل لا نايا ناما ف قات مام 5-5 
06221 و 
1ع ]تدع تام 
نات ع اتاد نات 





من الممكن حماية البرنامج من أخطاء الفيض إذا لم يتم استخدام تلك 
الوظائف الخطرة خاصة في الأماكن التي يستطيع المستخدم فيها إدخال 
عاناف للتررامة منواء من الكنيوية امن ملق عر ة الترنافة ادهن السيكة 
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الفصاء 5 





حيث يمكن استخدام وظائف بديلة أمنه .. فمثلا الوظيفة لإمع:]5 لها بديل 
/(5]11100 يقوم بالنسخ بعدد محدد من البايتات يتم تحديده مسبقا. 

والخطر ليس في الوظيفة لإ5]16 وحدها بل توجحد وظائف اخري عديدة لا 
سدع المحال لذكرها حميعا وساكتفى بسيردها .: فعليك بالستتكمال البحف اذا 






]51/11 0ولأءمرع | 
>5 أ05/ا كأع0 | 
|15 لإلاع/ا لم516 | 
ادام لتاع/١‏ 51621 | 
|15 لإلاع/ا مم5 | 
كا5أ؟ لرع/١‏ أمق50 | 
كا5أ؟ لرع/١‏ 5563111 | 
كا5أ؟ لرع/١‏ 50311 | 
>5 للاع/ا 5311 | 
ادام لتاع/١‏ مكلا | 
/>ا15؟ للاع/ا 7/5631 | 
لكوأ لماع/١‏ 75563115 | 
لاوا لإتاع/١‏ 50 | 
/كا15] للاع/ا لإمعع 51 | 
ل>| 15م 5115 | 
>ا5ا؟ عأ3ع0100 1 اعاع0 | 
“ادا عغأ3مع100 عأع0] | 
»اا عأ3ع0100 عأع0 | 
>ادا؟ عأ3ع0100 0ع | 
»!15 /لا0 ا لإاممعم | 
>!5أ] /لا0 ا كأع] | 
>ا5أ؟ //ا0 ا لإدرعمطاعما | 
>!15؟ /لا0 ا زالقاقاءلقة | 
»!15 /لا0 ا لإام 5166 | 
»ا5أ؟ //ا0 ا 5060 
>ا5أ؟ //ا0 ا لإ10 51 | 
»اا //ا0 ا أ ام اكلا | 
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مانم بن حب صن ح0 






1 0011001 
3 ل 


الحقن الديناميكي 


0 هه ط11(آ 


المفهوم وكيفية التطبيق. 

إنشاء مكتبة االا. 

الطريقة الأولي 067630 لمع جاعادع6. 
الطريقة التانيةع/١3)‏ ©00). 

الطريقة التالتة|100! 7/اع]أ5لاد. 
0010 621م. 


الحقن الدبناميكى 





- المفهوهم وكيفية التطبيق 


الحقن الديناميكي 100]ع17[6 0310012الإ1 هو عملية إجبار تطبيق ما يعمل 
حاليا علي تنفيذ التعليمات التي نريدها .. عن طريق حقن الشفرة به. 


تلك التعليمات من الممكن أن تكون تعليمات آسمبلي مباشرة .. أو نقوم 
بحقن مكتبة اا0 بها جميع التعليمات التي نريد تنفيذها. 


حقن مكتبات اانا في التطبيقات بس كوم طوال الوقفت من قبل برامج عديدة 
سواء برامج ضارة أو نافعة .. حيث توجد برمجيات ضارة عديدة تستخدمه في 
الاتصال العكسي وحماية الملف الضار من محاوله غلقه أو حذفه .. وكذلك 
السيطرة شبه التامة علي جميع ما يقوم المستخدم بعمله. 


حيث مكتبة ال اا0 لها نقطة بداية 280106 ل5أ0ع .. والتي إذا ما حملت 
فسيصبح ال اا بمثابة تطبيق فرعي من التطبيق الأصلي المحقون به. 


وأعني بتطبيق فرعي أنه تطبيق كامل يستطيع القيام بأي عملية وكأنه ملف 
تنفيذي 25 .. ولكن سيكون موديول 11001016 داخل التطبيق الرئيسي. 

وقد تطرقنا من قبل لمسارات التنفيذ 156305 في الفصل الحادي عشر 
الخاص بالبحث عن الملفات .. وسنعود إليها في الفصل الحالي. 


وقبل أن نخوض في هذا الأمر علينا أولا معرفة بعض الدوال المهمة التي 
سنستخدمها في هذا الفصل. 


© دالة 5ووعع0:طدرعم0 
تقوم تلك الدالة بإعادة مقبض لتطبيق موجود. 


ا أماتاع فق أه عافضقط 3 كتقللاع مملتعصلة عععع ور نازرع درن عدا 
أعع زناه ددعع مام 


أعدعن ورنازرع درن عا انالاملا 
3 ددع دن 3ق م بككع حت لو جاع دن انان لاخا ذا اانا 
عغعصة 1ع لاما عامصضوط م و كالن ةعقسم انانا8 
111 تلع | ددعم مام لم أن كمع عدن اران لاخا نا اانا 


:/ 
حيث لها .3 معاملات. : 
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الحقن الديناميكيىي الفص 6 


الأول 5وودع©©08ع:9651/لا0 : راية تحدد حرية الحصول علي المعلومات من 
التطبيق .. ومن القيم الثابتة التي تحدد الراية , القيم التالية: 


مسار تنفيذ بدالة 30ع11 ع0 ممعلاع انع 
كل 1 عض 
بدالة دوعع0(طع]3 7 امطاء [ 


إتاحة استخدام مقبض التطبيق في 1101 ماعط0_الا/ا_وكدع 0000م 
التعديل علي ذاكرة التطبيق بدالتى 
/01 راع الأددعع0طع ]الاب إطاعءع 150 ونناا/ا 


إتاحة استخدام مقبض التطبيق في رامغ ظا_لا/ا_ددع 00م 
القراءة من ذاكرة التطبيق بدالة 
/013 رع الاأودوعع3020ع] 


إتاحة استخدام مقبض التطبيق في 11]//ا_الا/ا_ودع )0م 
الكتابة إلي ذاكرة التطبيق بدالة 
/013 ماع اللاودوعع0طع)] ]لاا 





الثاني ©0106:16113001 : قيمة 8001630 تحدد إذا أردت توريث مقبض 
التطبيق لاي تطبيقات جديدة منشئة منه .. ونضع قيمتهاع3|5. 


النالتث 2:0©65510/ل/01 : يحدد معرف التطبيق المراد الحصول علي مقبضه 
ويمكن الحصول علي معرق التطبيق بدالة5510ع30206عآ 01/1( /الااع6. 


وبعد نجاح الدالة تعود بقيمة المقبض .. وبعد الانتهاء من المقبض نستطيع 
غلقه بدالة 610561130016 وذلك بتمرير قيمة المقبض إليها. 


© <اله 510دعع2:0ل دجع: ذا 1 11001 لالا اع 


تقوم تلك الدالة بالحصول علي معرف مسار التنفيذ 715:630 الذي قام بإنشاء 
النافذة .. والذي يكون بصفة كبيرة معرف التطبيق الذي أنشأ النافذة. 


والذالة تجللب الحضو قلي فيضن التاق دوقي فسن ال كنا قال رمع 

نافذة للتطبيق المراد الحقن به .. مثل التطبيقات الخدمية 561/1665 .. 
وبالتالي يوجد وسيلة اخري للحصول علي معرف التطبيق بشرط معرفة اسم 
الملف التنفيذي الخاص بالتطبيق .. ومن ثم عمل تكرار لجميع التطبيقات التي 
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الحقن الدبناميكى 


تعمل حاليا علي النظام ومقارنة الاسم إلي أن نصل للتطبيق المحدد وذلك 
يتم باستخدام الدوال التالية : 
5101م3253ماع|00 آ عأوعر) 
1151 5532ع000 
اع/١|5532ع100م‏ 
سأترك لك تلك الطريقة للبحث عنها .. وربما نتناولها في جزء قادم .. ولكن 
حاليا سنتمسك بالدالة 5510ع7001/111630206/ا/ااع© والتي لها المعاملات 
التالية : 


أن عا لاضع ل عطا عمعشم ماع ضملأعصلة ل اعجعع مد نالدع ذا | تحمل درالالااع دا عطا 
عط , أ اأقضمااتره ,قصة نخصل صاتتئ ع الاععمه عط لمعمأقعنع أقطا لممعءطا عط 

تلت اأعظطللا قلط | نتخمك سات عغطا معماقعء أقطا عمععهنام عط أم مع ةاصعلا 
نلعتل عاعة | تحمل درالالااع دا عطا دع لعدرع مراك 


أل أعدعء دعر ثنال0دع: 1ا! | تحمل نر الالااع دا اغا ذا اانا 


بان لترائتة أن عاترو مر السام لا ااانا 
5ع مهنم لم1 عاطامارةق"” أم 5دع نلق م ممعم م تمص لأا نا لاا ]8 | 
1ك ]| ]علا 1 


المعامل الأول 10لالاذا يحدد مقبض النافذة وسنتعرف كيف نحصل علي مقبض 
اي نافذة من الدالة القادمة //5001أ/ا/الما. 

المعامل الثاني 210©©65510/ل1001 وهو مؤشر الي قيمة (0151//ا0ا يخزن به 
معرف التطبيق. 


6 <اله /1001 ةلالا ل دآ 


أعنعا-درهت1 عطا ما عاقضقط عطا ممع راع ممتعصرة متحماعدرالأيال راع عطا 
نع الأاصعمة عط طتعتقمتر عصسقط أتخمل قات قضة عقلقة مدقاع عخمصطابه تند نانب 
كثنه ضاف قااطع تاعتقهعة امم ععمل قماأعصضلطة علط | .كقصائماك 


اناه ل نر الال درطا ذا ااانا 
عملقط 55قات مأ عألادم ثم وكات الكت داعام 15114 0)20] | 
مقط “نمل تاذ ما عأمادم كم صنت لبا اس 0215114 | 


م 


تستخدم دالة //1001//17001 للحصول علي مقبض النافذة الرئيسية فقط عن 
طريق تحديد اسم النافذة ©3007[ //1//15001 أو اسم فئة النافذة ١300©‏ 1355). 
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لحقن الدناميكي 


فمثلا نافذة الآلة الحاسبة تكون باسم "3601انا6ا3©" .. واسم فئة النافذة هو 
"50101" .. 

بالتالي إذا كانت الآلة الحاسبة تعمل حاليا علي النظام .. وأردنا الحصول علي 

"031111302" 20012 ,آ1آ لكآ ,206107 0111م 5*1 مع1127701 

06 

لاا ا 1 8" 1 مب 1616 121 51 1570786 

02 

ا ل ا 16 ا 1 5 ا 200617 0 21 111570156 


مع ملاحظة وضع النصوص داخل متغيرات .. وأي من الطرق السابقة سيؤدي 
إلي العودة بمقبض نافذة الحاسبة .. وإذا عادت الدالة بصفر فهذا يعني أن 
الحاسبة لا تعمل حاليا علي النظام. 


وللعلم توحد دالة باسممر «ع/101//17001 تستخدم للحصول علي مقبض 
النوافذ الفرعية من النافذة الرئيسية. 


6 داله باامخأعع1101ناع:الاناأا06 


تستخدم هذه الدالة للحصول علي مسار المجلد الحالي الذي تم تحميل 


باص اع ع ال أمرع نات عط ععننع راع تندااع طلا بتإماع ع ١‏ اللأتاع سانااع ها عطا 
855 اطلام أمعايكت عط غم[ 


ا لاما ع ١!‏ الاأاتاع ١‏ مااع جا لأا نا نالان] 


اعقالاط لماع عرزل آم كماع ققطع صل مداع ل اوفع قم ناكا نالاانا 
للإصاع عرزل أمع رباع رمأ معأاباط آم عدع مله “م ك اناكم +11 215 ا 
:1 


المعامل الأول يحدد حجم المخزن .. ونضع به أكبر حجم للمسار256 بايت. 
المعامل الثاني مؤشر للمخزن والذي سيستقبل مسار المجلد. 
© دذاله «اطاعه0ال6اتن الا 


تقوم هذه الدالة بحجز أو إحالة -أو الاثنين- منطقة في الذاكرة في مكان الذاكرة 
الافتراضية للتطبيق. 
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الفصل 6 الحقن الديناميكي 


أن تضاقع؟ 3 ,تلكصط '(ه , 5 ]انمع , ععتضفدع؟ ممااعصلطة كرطع مالكاحسكالا عط ا 
عطا .كععع مام لع اأاععمك ق أنه ععهمة مدع 0م30 أقلاارئ: معطلا متطلائه مخزلت عملم 
ملقم نآ قم أة عماأاة 1 مصعم عطا ممع أأقللأاضا مملاعصلا 


عاك والكفادنانا ناانانان | 


بتامتصعمم عتأةعمااة مأ طعتطف متطتاض ممععم]م “م رقت عدم ] اناالملا 
مملئوع مااة غم عدعللة وصتفواة لماوعل م رققط نان ثم نااناناظ | 
عأةعمااة ما صداوة؟ أم ,ععائط ما رععاك “نم رقع احاباك لاغاذالايان] 
ملتةعمااة ثم عمسلث بعهما! ممح ع داكن ناكا ذالالانا 

املاع ع امام عمعععة أه عمنا م ا لام َآآإ 


للدالة 5 معاملات هم كالتالي : 


1 - 55ع©82:0! : مقبض التطبيق الذي يعود من جراء استخدام دالة 
25 2)2. 


2 - 108001655 : مؤشر إلي العنوان المطلوب بداية التخصيص منه في 
ذاكرة التطبيق الافتراضية .. وإذا أعطيت لهذا المعامل القيمة انالا 
فستدع الدالة تحدد عنوان البداية بنفسها , وهذا أفضل. 


3 - 01/512 : تحديد الحجم بالبايت للمساحة التي تريد تخصيصها في 
ذاكرة التطبيق الافتراضية. 


4 - عم/9ا1511062311011:1؟ : قيمة لبعض الرايات تحدد نوع صفحة الذاكرة 
المخصصة .. والراية التي تهمنا لهذا المعامل هي : 
0011)_الااعا الا 
وهي تجعل الدالة تخصص مساحة تخزينية سواء في الذاكرة او في 
ملف »11 2306 علي الهارد .. ويتم تهيئة تلك المنطقة بقيم ا الالاا. 


5 - 1900160 : قيمة لمجموعة من الرايات والتي تحدد نوع الحماية علي 
منطقة الذاكرة التي تم تخصيصها .. من تلك الرايات التالي: 


اناحة الترخيض: بالقراءة !ا الا0طمعه_ع ممم 
إتاحة الترخيص بالقراءة والكتابة غ811 /الاممعه_عممم 





إتاحة الترخيص بالتنفيذ (لا تسري أي غ1نامعلاع_عولمم 
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لحقن الدتاميكي 


عمليات قراءة أو كتابة) 


2 شد 
اتاخة الترخيض بالقتفية: والقراءة مدعم ع 1 نامعلاع_ع ممم 


إتاحة الترخيص بالتنفيذ والقراءة والكتابة ' #118اللامم2ه_ع 1 نا0علاع_ع مم 
إلغاء الوصول الي المتطقة المخصصة 155 ع 6م 


عند نجاح الدالة فتعود بعنوان البداية للمنطقة المخصصة في الذاكرة .. بينما 
تعود بالقيمة | الالاا إذا فشلت. 





© <داله »اععماجد آلا 


تقوم هذه الدالة بتحرير أو إزالة -أو الاثنين- منطقة في الذاكرة داخل ذاكرة 
التطبيق الافتراضية. 


لإضاقع؟ 3 ,طامط زه ,قعللصلم إ1مععل ,مفدموعاع؟ قماأعصرة #رعاعع2 الهسارانا عدا 
.855 ع مام لع الاععمرة 3 أه ععقهمك 5ددع 3001 ادناه عط متظطااهة خم ضرعم أن 


أخااعع: -القنراا اناناق8 
رقم ةحصم عا اناتام لا 
رقطع نات كم لاانانان | 
بم ا حانان لا نا نالان] 

ممما عع ناك لا زا اانا 


١ 
: للدالة 4 معاملات هم كالتالي‎ 

1 - 5وو5ع©12:0 : مقبض التطبيق. 

2 - 08001©55! : عنوان بداية منطقة الذاكرة المراد تحريرها. 


3 - 01/5126 : حجم المنطقة بالبايت المراد تحريرها. 


4 - عملإاعع:/لال : راية تحدد نوع عملية التحرير .. لها قيمتين هم : 


يتم إزالة المنطقة ولكن تبقي المنطقة 0رطح]_الازع لا 
محجوزة 





يتم إزالة المنطقة ويتم تحرير المنطقة عكخطاعظا_الاع الا 


فو كاه الذالة قرعو بضية قير ا لمدفر. 
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الحقن الداميكى 


2 داله لإنمتترع اللووعع0:طع]1 ثلا 
تستخدم هذه الدالة للكتابة في ذاكرة تطبيق محدد. 
اع اأاعع م5 3 تلا تلص تعض كع متف تلمااع صلا 'بكره تريع الالعدعع مرناع ]رالا موا 


اه رعاطاكععععة عط أكلاما صا معت أت عط ما قعرة عرلاضع عطا .ددعععدمم 
.1315 تاماأقزع مره عطا 


اده تيع الاأعدعع ورناع11ولاا اناق 
ممع عملم ] انااااملا 
مع طناك لبدد دوم ل]انانياس | 
اع بكم لااناياظ | 
بعدنكم للخا نا اانا 
رك اا امت راط للد عطسي لالص لاا نا نايا ]0 | 


١: 
: للدالة 5 معاملات هم كالتالي‎ 

1 - 1821:0655 : مقبض التطبيق. 

2 - 105356800155 : عنوان بداية الكتابة في ذاكرة التطبيق. 

3 - “”اع11لا8م]1 : مؤشر إلي مخزن به البيانات المراد كتابتها. 

4 - 1512 : حجم البيانات المراد كتابتها. 


5 - ذداعغ1: لالاوع]ا/ا11112:0188الام! : مؤشر يستقبل حجم البيانات 
التي تم كتابتها بالبايت .. ويمكن تجاهل هذا المعامل. 


115 


لحقن الدناميكي 


حكهم 


كل 


داله 20ج2ع11 1 ع17110ع12ع1جع1 0 


إذا كنت تتذكر دالة 16366111630 كانت تستخدم لإنشاء مسار تنفيذ في 
التطبيق الحالي .. الآن دالة 30ع1151 06366167706 تستخدم لإنشاء مسار 


5لا أقطا عحعرطا 3 كععاأتعرع تاملك نلا قتع ذا | عتمرورع لماوع ا عط | 
.55قع مام اعطامصة أمه ععهمة ددع للق عطا ما 


القع تا | عامرررع أاأعادع: ا ع انالاملا 
بععع عم عم ع انااالملا 
رقت لاطا موصعم ما 5غ ا لا8ااما! اثى_ ١‏ المالاناع 5ن | 
قداث ناعح ‏ طاباراك لاغا نا لالانا 
قمع نان كراج اص 1١11‏ لاا _ اخاث | 5 _ناشع !!!1 نا | 
بلع عمط ونام ل]انانان | 
بك لم دعم راان لاا نا اانا 

واتحطمم رصا اغا نا لانن | 


ِ 


معاملات الدالة هي نفس معاملات دالة30ع11 1318 .. لا يزيد عليها غير 
المعامل الاول والذي يحدد مقبض التطبيق المراد إنشاء مسار به.. 


1 


2 


1 
زن 


١ 
حل‎ 


١ 
دق‎ 


١ 
0 


5 : مقبض التطبيق. 


5لا 1»2110 ١م‏ : مؤشر لبنية 155لا112_811518الا520 تحدد 
الخصائص الأمنية لمسار التنفيذ .. ولن نستخدم هذا المعامل ونضع 
قيمته االالا 


215126 : يحدد الحجم الاستاك بالبايت الذي تريده لمسار التنفيذ 
الجديد .. وإذا تجاهلت هذا المعامل ووضعت قيمته 1الالاا فسيتم حجز 
حجم فسافي لخدم ممار التفد الافتراضي النطوية. 


55 : عنوان بداية إجراء مسار التنفيذ . 


1 : يستخدم في حالة إذا أردت تمرير معامل إلي إجراء 
المسار .. وإلا فنضع قيمته ا الالا . 


13015 : معامل يحدد رايات إضافية لمسار التنفيذ تتحكم 
بعملية إنشائه .. لن نستخدم هذا المعامل ونضع قيمتها الالا. 
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7 - 0ا301ع111م| : مؤشر لمتغير عددي 32 بت .. يستقبل معرف مسار 
التنفيذ .. ولن نحتاج لهذا المعرق ونضع لقيمة المعامل ا الالاا. 


وبعد نجاح الدالة تعود بقيمة مقبض المسار .. وهو غير مهم ويمكننا غلقه 
بدالة 010561130016 ونمرر لها قيمة مقبض المسار .. وستظل المكتبة محملة 


بينما إذا فشلت الدالة فستعود بالقيمة صفر. 


© اله ععط ور[لالا 


تستخدم هذه الدالة لتشغيل تطبيق محدد. 


تلضاأةع اأاممة لع الاععدرة عط خقل ملأعصلة عع»رعا تالالا معطا 
عع انرالانا 1 ااانا 


عضا لتلة تامع أن مدع للق م اتام 14 [ 05 0] | 
تلصالة ع اأامدمرة معط رما عائكاع خم ل لاسن م بارال ل حاتم ا [ اانا 


١: 
مؤشر إلي نص به اسم أو مسار التطبيق المراد‎ ١1061701176 المعامل الأول‎ 


المعامل الثاني 0071051101 يحدد طريقة عرض التطبيق ومن القيم الثابتة 
التي يمكن أن يأخذها هذا المعامل الأتي : 
ع10نا_الاك 
غ11)11112_/الاك 
غ11/11117_ناراك 
مع 1112م 01/1 ك_ناراك 
01/11/1117 ك_ناراك 
01/014 5_/الاك 
عند نجاح الدالة تعود بقيمة أكبر من 31. 
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> إنشاء مكنبة.1آ.121 


نستعرض الآن كيفية بناء مكتبة |0 من داخل 8308511 .. حيث نختار 


أمع(20 /ثاعلا ثم نختار نوع المشروع هو 2020 اانا .. واسم المشروع 
باسم ا ا(الإالا. 


تلرراء اط 17 تزاظ| - اران لكات زكرا 
'أعاحاممعددم 


!١1كدا‎ ١١ ل‎ 


عم | ادعزممم 

تلص ) تزحرث ودن] 0 حرحرم تتس بام 0 
أتنرة أ عزنا 0 حرحرث عادكحد 0 

أقط ععاقم ممع 2 © أععزممط |ان ل 
أععزصر8 بعد 0 

أععزصط 0118 


اععزصعع عيلن مام م 
كعم صدذا حرحرم تتختصابا 0 


حرحرت ومن 0 


2اة|"ا ا ددزدمع 
ااا مادعنا ا دعزدمع 


عاد داعدزومم 





وفي النافذة التالية سيطلب منا 5308511 اختيار 162001366 .. لا نختار أي 
تمبلت ونضغط ألاء/١!.‏ 


وسكتظهزر نافذة روا العلقات الفظلوي إنقناتها ..تتاكن:من اخمار فلف 
التعريفات (066). 
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انسدة 


615 ! 6 ذ5عاذط - لندجزالا أععزمممر 
داقع عاك 


مر 
117 





ع8[ ] 


صطهم ع0 [ت] 


مقع ععوامع 


] [8314 


] [ "02 
|] 865 





بعد الضغط علي ١/6‏ ستظهور النافذة التالية : 


ععلداا - لعنددأللا أععزممم 
ناصعاها مادام 
كعاباءمل"ا عاطرعودث [ ]| عاإتووه [ ] 
101 عااتزدوص [ ] عاحامعددم 
اتنا 
واانا8 
60[ ] 
حداةا[ ] 
وباطع اا دنا8 [] 
اث ه6 [ ] 


1 علاع. ا 8ة رن ,4ك :ا اتام 

1"41",2/ مودامصمر حامر أأمعم عر عاكاع. _ااناا8ة رنارك احا ]ددم 
عار كباران نال[ ابا اع | كأ كطلاكر عاخزع, >الذا1 اا نارم :كاملا 
“تالا 

ك,"وطمزلاماعة" رمرن ١‏ (وناطع رثا دنع 

5ن علق ارزع , 11/1825 8ة رن رزطه,ع ]5 :زط 10 مم8 

"1"41/ مودادص/ دعل لمعم عر علاع. الطاعؤر0 زط * ١‏ :عاناكمانا لدت 








نلاحظ بالنافذة السابقة أن سطر ربط مكتبة الاا0 سيكون كالتالي : 
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1-15 :11 نا 51185775 / -1آ1/ 1121 
ع0 . :1197101 -آ:آ1157710١‏ هع » ١25530251112203‏ نك : 2817 / 
063 . آ115781:1 ١11571:‏ قععع ١8502511١2203‏ :ع : تالضع 1:18 / 


وبعد الضغط علي أومانا سيتم إنشاء المشروع 


ا انابزاما - الإكفله! 
ماع تععةل" مصاعغمت ستصصضمتت كاصص عناقكم عععزمعه غأقصرمءع سعن زع عاط 


دعا ردموومع 


ا كك 


لامرامز ث1 


لإأطاماعديعم كاك 

عضا لاناساك ...أ ا 
عدوااما تناح 
أعملاميام 3 


ع إعدمم 


#* هاه © 5 





عددعاعم - عقوم ِ 


نقوم بوضع التضمينات التالية ضمن الملف ع15. لامالا : 


122 . 57712001775 12111106 
©1:2 . 11561232 ©1110 1121 
1ق . ممعره مق قمعو وو 1032 6 تمل 





1111110611315 1115© 232 . 1 


وسنقوم بوضع الشفرة التالية ضمن الملف4650. ا ا(الإالا : 


0106 
1ع200 7 ممعم 1ه 32م 3م520 ,غ132 1ع2100. 


562511757 ©35ه6م ©2ه20: جتمءع235 2ه61مه 


121110© 1577101. 
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الفصل 6 الحقن الديناميكي 


. 2000© 


,211081 : 2502 ع725 2 ,111752881101 : عن طوع ققط1ط عه0ع2م 111122237 
011 ثاثالا : 01 ©2757 1715م 


101096 12 نذا ب[ن] ك2 ج01 28 010/106 1 1ل 
, ("07ع©30ه16آ 1211" ) 0121 ,8111 ,53606801 5م11 ع1125701 
آ[1آ ]8 , ("1"): 0121 
1171 0555 031/16286215201 2 ' 615611 
, ( "2103060 211" ) 0121 ,81111 ,53064282017 وع11 ع1 1127570 
1[آ7آ[8 , ("2"): 0121 
6215© . 
لا" ,337 © 57ه11 
اعم2 


جقطط 1111:1237آ 


2260م 533256116 
, (آطآ0آ71ك1 2*2 11 ع2" ) 011 ,811111 ,5306801 وع11 ع1125701 
آ1آ1] , ("!2311" )01 


أذ1ع©2 


جقطط ©11ع53328 





2110 1212277 


كل ملف اانا له نقطة بداية 5019/2011 في الكود السابق بإسمر 197](اعاانا 
ويمكتك :تغييرها إلى أى اسدهر آخر... 


المهم أن نقطة البداية هذه يقوم النظام باستدعائها في أريع حالات : 

1 - عندما يتم تحميل ال اا0 [06255_8778611هط_لاص]. 

2- عندما يتم تفريغ ال اا0 [06255_0818611هط_لاص]. 

3 - عندما يتم إنشاء مسار تنفيذ ضمن التطبيق [7786©11م_ممعهل!1_لامص]. 
4 - عندما يتم غلق مسار تنفيذ ضمن التطبيق[08186©11_ممعهلا1_لامص]. 
إحراء نقطة البداية يجب أن يكون علي هذا النحو : 


1 0//انا: هكقع] لال ,عن للق [ 1105 ا:ع1306أكص1آط 2م]ام لإاأمعااما 
0//اما : لع/رعوع انام 
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الحقن الديناميكيىي الفص 6 


حيث يجب أن يكون له 3 معاملات هم كالتالي : 





1 - ع610251306آ : مقبض مكتبة ال اانا الذي يعطيه النظام لها. 


2 - 01/635017 : سبب استدعاء نقطة بداية مكتبة ال اا وهو أحد 
الأسباب التي قمنا باستعراضها الصفحة السابقة. 


3 - 0ع/اثاع5ع1/1م : معامل محجوز. 


ولابد أن نعود بالقيمة تالا18 إذا أردنا استمرار عمل ال اا2 .. لإننا إذا لم 
نعد ب تالال1 سيحسب النظام أنه يوحد خطأ في المكتبة ولا نريد 
استهوا ها 

ومن تم قمنا بكتابة إجراء باسممااع1الإ53. 


الآن سنقوم بكتابة السطرين التاليين في الملف1.8©6ا0//! : 


آدا0ا1/7 لاكلش كلظ ا 
5377211 220115 


السطر الأول يحدد اسم المكتبة . 
السطر الثاني يحدد الإجراءات التي نريد تصديرها في مكتبة ال اا يسبقا 
التوجيه 27)00115. 


وإذا كان هناك أكثر من إجراء نستطيع تصديرهم كالتالي : 


82 005 
537211 


ره لت م و22 
5*3 
١ 4‏ 1 535721 





حيث القيم (10©) تجعل التصدير بالتتابع (0101731 لإ5) .. كما هو موضح في 
الصورة التالية : 


2آ1 

















الفصل 6 لحن الم امك 
علمكل"] قبع عووممل" | اخمالضت عومول" | قتع ممعغعمررع اتماتمن؟ 
أكااتجعت صباا] لخت بارا تدثانا | زكمصأعغعصرطم) 
دااع تام؟دد كانت لانارانا لانازانا لا4نا1 لانازانا 11للالالانازانا 
دااع ا؟دد شناراتزالارانا 1لالالا 3ك 1 االازانا اانا انانانا 
دواع ةد عالاكنالارانا #لالنانا ذلا 1 لالازانا انان الانانا 
تدااعل اكد الال الازانا لالالا ل 1لالالنانا انال الالانا 


الأن نقوم بالضغط علي 81:1+511121+825 لترحمة المكتبة وتحويلها إليااها. 


وسيظهر لنا الملف [1ا1.0ا(الإ11] .. لاستخدام هذه المكتبة يوجحد طريقتين: 


1 - التحميل الضصمني [03011160! 1111011115 ] 
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حيث يعمل نظام التشغيل علي تحميل المكتبة وربطها مع الملف 
التنفيذي قبل ان يبدا عمل الملف التنفيذي..وهذه الطريقة نستخدمها 
في برامجنا طوال الوقت .. حيت عندما تقول : 
مأ 32عكن ع0ناأعما 
10|. 32عكن مأاعل0بااأهما 
ومع وجود المكتبة [32.0ع5لا في 5]60732لإ5 .. فهنا نقوم بتحميلها 
ضمنيا مع البرنامح. 
يمكننا فعلا المتل مع المكتبة لدينا حيث : 
نقوم بنسخ الملف (ذا. ا املإالا إلي المجلد [16350321116:©] أو بداخل 
مجلد البرنامح. 
نقوم بنسخ الملف (ا0.اا(الإالا إلي المجلد [032ع5!/5١1/001//5/الا١‏ :ع ] 
أو بداخل مجلد البرنامج. 
نقوم بإنشاء ملف باسم ©10.االإ/! بالمجلد [06ناعم١32ماكةم!ا:2]‏ أو 
بداخل مجلد البرنامج ونضع داخله تعريف الدالة1||0ال/إ53 التالي : 
1ط و)|اعاالاج5 


ثم نقوم بتضمين المكتبة بهذا الشكل داخل مشروع/830851: 


عنأ.اارالإالا علباعما 
10|.اارالالا ماأاعلباءما 
ولاستدعاء الإجراء 0ااع1الاج5 فقط نكتب : 


0ااعالالإج5 ااه © واإعلتالإج5ك عامناما 


الحقن الديناميكيىي الفص 6 


2 - التحميل الصريح [030111:0! غ1©1ام؟اط ] 
حيث لا يقوم النظام بتحميل المكتبة إلا إذا طلبتها أثناء تنفيذ البرنامج .. 
وذلك يتم عن طريق الدوال التالية : 





ه0301-1131 ا 
00115 
/ا31اطلاععم] 


وهذه هي الطريقة التي نستخدمها في حقن مكتبة الاا9 أثناء التنفيذ. 


( "1011 . [آ1597101" ) 0131 ,160301123237 ع1125701 

2375© 1151م 

("116ع5372") 0117 ,ع3 » , 5 220620025 8ع ع115701 
1© 11177014 

2356© جرهم 

»© ,1123237عع2 "7 ع112701 


حيث يتم تحميل المكتبة بدالة /ا1131-ا0301ا .. وتعود بمقبض موديولك المكتبة 
والذي ندفعه مع اسم الإجراء إلي الدالة 55ع208001]ع0 لتعود بعنوان الدالة 
المصدرة في المكتبةه 0اع1الإ[53 .. ومن ثم نقوم باستدعاء هذه الدالة .. 
ونستخدم في النهاية الدالة/ل1ة:طناعع:" لإزالة المكتبة. 


والآان سنستعرض كيفية حقن مكتبة في تطبيق .. وسنختار تطبيق الآلة 
الحاسبة [316.©6<“6)] كمتال .. وسنقوم بحقن المكتبةء [اانا.اانالإالاا] التي 
قمنا بإنشائها. 





نقوم بإنشاء مشروع باسمر [12[6800 ااما] به زر باسم [11/[18521_لاا8] 
يستخدم لعملية بدء حقن المكتبة دخل الآالة الحاسبة. 


داخل الملف [1[6©611011.10 اانا] نضع التعريفات التالية : 
ماحل كنتصاء مامت علعبااعمرا 
عصل ع اإعمععا عساعصا 
عطاء 2ت نعكبا ععبااءعدما 
عطل ال عصوم ا عمساعصا 
تلاكة, خط اع ةلطتعط عقصتك3 لرمقصل ةنا عاعبناعصا 


0 


ذخا دنا طلْر كا كلا 
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الفصلء 6 الحقن الديناميكي 


طلا تاعصعها حازاعلباعصس "” 
طلا تعدبا طاتاعلباعصز 5 
طلا 32 عدده ا حاتاعلأساعءعمر ه 
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لات رت ]نر الات رت عبان [ 1لا نالناك: لاآالالظاظط عص وان 11 
12 

أدكاانع. 13 


1لا لالت 1تانااشإنا_ناناً 14 
انالا لياوع [اعلل"ا[_لمذااعغ 15 
ا لل ا ا امم ك1 


غأقل. ”1 

(لا) ترباكل ذاكع دحأك عباط 13 

نار" اص تانادات-" دحأك ع1 صاطك 19 
لاى”أأك. اناما طك 3012ا"ااانا 20 
لاء "اا تاعصععا"” داك اإصصعها 21 
لا "شت (حاناةتص ا" داك طاناققصا ‏ 22 
لاد ل لق ال لي اد ل لاو ل لق ل ل ا ال لقو ل لق ل ل اد ال لل ل ل ل لي لا ل لق ل ل ل ل ل 00 لدت 
*قخأهل. 4ت 

افاء عددةأئقصاط ‏ 25 

فاه اعمععاط ‏ 5ت 

# عل “عتعشضطناتغقصا 27 

235  طاقاع‎ 00 

افاء 1عاة ا 23 

فاه تعالانا 30 

00 اتكشاانا 31 


2 ل لاتععط| سملم د 
م ال لي لله للد ال لي للق امب ال ليق لله ال ال للقي للد الل لي للق امي ال ليق لل ال ال للقي لي الل لي للق م ال لق لل للق ل 56 


السطر 19 : اسم نافذة الآلة الحاسبة الذي سنستخدمه للحصول علي 
قبضها. 


السطر 20 : اسم ملف ال 011 الخاص بنا .. وسنقوم بإضافة مسار المجلد 
الحالي إليه ومن ثم يكون لدينا مسار واسم الملف كاملا ونقوم بتخزينه في 
المتغير اع]ألاه. 


السطر 26 : متغير يستخدم لتخزين مقبض موديول المكتبة"!6132.01م61)]". 
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انسل 6 
السطر 27 : متغير يستخدم لتخزين عنوان الدالةلإ!16131-ا030٠.‏ 
السطر 28 : متغير يستخدم لتخزين مقبض نافذة الآلة الحاسبة. 
السطر 29 : متغير يستخدم لتخزين معرف تطبيق الآلة الحاسبة. 
السطر 30 : متغير يستخدم لحفظ الحجم بالبايت للمتغيراع]]لاط الموجود به 


مسار واسم ملف ال اانا .. وذلك لكي نحجز له المساحة المحددة في ذاكرة 
التطبيق بدالة “3141106 ألا. 





التسيظر 313 متقير يستخدم لتخرين عتوات حجر المساحة :في ذاكرة 


السطر 32 : متغير يستخدم لحفظ مقبض المسار الذي يعود بعد استدعاء 
الدالة 0جعغط ا عأ مدمعناعاتء 1ن . 


وشفرة الملف [17[66]101.8517 اانما]) ستكون كالتالي : 


داتات, 
اعقصم تصموعم غلط 2ت أأقعل اه ,غأهاآ اأعلعصت. 
عملا اممعه عدت 110118 تإتالاء 35 ١الملانرتن‏ 


اكلا خنطا ععزم] اانا عاعبلاعضا 


00 . 
:511 
ا الالكارعاعصدتاعاباعد “اعت ععامجوصر 
ع ععداة أ كط[دا لولم 
5د تنه اختص لالص غلم[ ععا مسن 
ا اللالكار حص عوانا العلعق, ا الالكا, 1تاتتات[نا_نانال ععحة أ كعصتطرصةوءوط«معودادانا ععامجنر 
لاروكوععم طذيرع عيعاوين] 


امم 
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حص 


ذخا ذلا صلم كا 


كا [- لذلا لكلا 


بم 
نا 


الفصل 6 الحقن الديناميكي 


لالت رت ]| مرت تنم [لنأرف ته بتما: ورت تع شن 1 لكاآلنا: وك ا«أبا, نالك اتئاح: متبتانا عصنام عمعتاوانا 


2د الاقم اودر 
تانلات[نا 15111_ا«اتاح د جوع 11 


لالخات ل“ طان_امارتباح دبوجع [زعواع. 
زحمة دمت تام لوعي دع بعسودم 
[ دل ورووءدنانت نامر نمي باع بعسووم 
1-1 ا2_لام- - يلمع 11 
علل"1_لااعح دبزهع آل 
أععزت] أادىه 
االلاعء. 
[الداع. 
كنا لان_امأبتفتح دبرهع [زعواع. 
لامك احا وداداناتصع ععجامجوضا 
عوع. 
عكاث اردع عورم 
اع 
[اللاع. 
علائا اردع منورن 
اع 
ماعديع عمعاوانا 


غنات أادعزت]1 
إعصععها ملاعم عاتصد عاتم "اعت ععجاوبن]1 
تمع اعم ععكانا نودم 


طاناكدتدا "لماعم اعصصةاط ددع مضعم مطعاعي عجاوبن] 
#تع, اععشحاناتتدا مدر 


علاط لماعت لاا قط_عزت اما ٠صاعع‏ نالدع لماعت ععاوبون 
عممداةااانا «لعلاعق عابط الاعف خدع ندا ععامسوسنر 


عباط العاأعمرصع ]ندا ععاوبجنا]1 
63 معااانا وحم 
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بو قم فم 
- تت نرا 


م 


ذخا ذلا 


كل 


ثلا [- اللا للظ ‏ لش مم 


ذخ يخا يا نكا يخ يخ يخ ز] زخن ريخش ب لبا ل 
ص 


ذا 
شر 


ذا 
ارلا 


از 
ل 


لذ با عا كا 
ا 


ما 


-1 


دنا 


الحقن الديناميكي الفصء 6 


: أت_التصاع 
عا | صانت!ا “لماعم انالك ماعط اعمط ععجامسن[] 
- دبزوع 1 
لكا ةا حبلي .عاقت عضا أخصص صاباص؟" 12 6 [ ام للاتالكاى؛زمععودددعل" عيعاوين 
لالذاطط؟_طط “,م | تالكا 
زالذانا- دجزهع 11 
اعم 
أأملاة. 
اثم نل تان ناك_بتباك ("عيع., عات" 16110 ]نا عصع مربت ععاومسصر 
لات عد بزمع 11 
و(" أمعاتالداقت عط نبت غخصص عاباص" )1غ | ام للانالكاى«مطعودددجعمن ععاوسهضا 
لالذاطط؟_ط “ام ا تالكا 
آعم 
أألاة. 
وه ذإززاا 
[الاء. 
إعاعاتا لماعم هع , ل[ادجمععح دا معط | منخصعمتتاعنث ععجاوبن][1 
12عاة ا تار كد داق ااض_كدع انطع ججععم م تادعمب عجاوبجن] 
تمع عات_اط لمكم 
ع 11بالالاناشطمط_اماشط, 1 11“لمانا_ ماعطا مع ا انام للاتالكاربعاقتط:«ععصااشاخبطعث؟ ععامبسن[] 
م ع, اعاعشاانا سمدم 
اال الكار دص الأنار ع اباط “املعم داعت اانا عاق كط تمصع “«أمجععو م مصا زرا عجاوبن]1 
ا الالكا لام لداعت اانا, اتاعافطاا_الناتصارنا, ااالكاردات_اطا معطا | عختصمع ععادعر ععجاوبن]1 
#تقع دمعءرا | سحعل"] حوكلم 
لا <-! فقعمط | شفعلا 11. 
| الالئارل عاندنا !١‏ »| ارلز تع ععزض1 اانا 1 1 ام اال الكائ#مععوددععمام ععاوبن]1 
عدععحا | بعل" «اعلعم عادمصدلاعكداءت ععامبجن][] 
عكطفع اعم_اماع كل حص ااانا ععفانا «اماعم عاك تطوتعدع خبطا ععاوبجن]1 
أأعدا. 
ا الالكام اال الكارز" تعااتع حصا ععرض]" 11١‏ 1 ا ا الالكاى عنم طعوددععامن عجاوبين]1 
[اللاعء. 
اع 
ماعدع أععزم] 
+531 أودرع 


السطر 27 : عند الضغط علي الزر1ع8111_10/185 يتم استدعاء إجراء الحقن. 
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ما 


كا كا كا 
كا [- لذلا لكلا 


ألا كلا الا الا الا لاط الا لاطا الا قاط [هد- [3[- [3[- [- 1 
لا صم زم نا لمر لظا كا [- قلا لكطظ لا مخ زع إزبنا كلم 


- 1- 
ا 


1-- 
1 لآ 


1ل- [- [3- للا 
لد الا كلظ لا 


ذلا اللا 
سم از إيبة 


كل 


دنا للا لا 


دا 
كا 


الحقن الداميكى 


السطور 42-41 : نقوم بالحصول علي مقبض "|ال.62اعممع)" بدالة 
ع11001/1!13101]ع© وتخزينه بالمتغير اع57]ع71 .. ولا داعي لاستخدام دالة 
030111319 وذلك لان المكتبة محملة بالفعل. 


السطور 45-44 : نقوم بالحصول علي عنوان الدالة ١0301161319‏ وتخزينه 
في المتغير ,0301168500ا. 


السطور 48-47 : نقوم بالحصول علي مسار المجلد الحالي ثم إضافته إلي 
اسم مكتبة ال اا0 لدينا وتخزين الناتج في المتغير 666]لاط .. وبالتالي يجب 
وضع مكتبة ال اا0لا"ا هنا في نفس مجلد المشروع. 


التحظور 55335860 :تقوورنا احهول هلك : لخر النانت الفساز الامكدة 
الموجحود بالمتغير :6]]لاط وتخزينه في المتغير 60 ||ا0. 


السطر 52 : بداية إجراء الحصول علي مقبض نافذة الآلة الحاسبة. 

السطر 53 : استدعاء الدالة /15001//ال15 وتمرير اسم النافذة لها. 
السطور 67-54 : إذا عادت الدالة بصفر فنخبر المستخدم بذلك ونخيره بين 
تشغيل الحاسبة ام لا .. إذا اختار تشغيلها نستدعي الدالة ععاع مالالا . 
ونختبر القيمة المعادة منها ..فاإذا عادت بنجاح فنقفز إلي السطر 52 ليتم 
استدعاء الدالة /15001//ا1501 ونعود بمقبض النافذة. 


السطر 68 : نقوم باستدعاء 5510ع302006ع17001//1516/الااع60 ونمرر لها 
مقبض نافذة الحاسبة للحصول علي معرق التطبيق(3|1). 

السطور 70-69 : بعد الحصول علي معرف تطبيق الآلة الحاسبة نستخدمه 
مع دالة 55ع200 0610 ونعطي التصريح 860655 411 .. ونتحصل علي مقبض 
التطبيق ونضعه في ا3)]. 

السطور 72-71 : نقوم بتخصيص منطقة في ذاكرة الآلة الحاسبة بطول 

مع ااانا ونوع الصفحة [01/1/11)_ل/اع!1 .. والترخيص عليهاء 111 /لامااع"ا.. 
وتعود الدالة بعنوان بداية تلك المنطقة فنقوم بحفظه في المتغير068001|انا. 


السطر 73 : نستخدم الدالة /551/©17019ع206ع]11//ا للكتابة إلي المنطقة 
المخصصة .. وسنكتب محتوي /1ع]آلا0 الموجود به مسار المكتبة ا انالإال/ا. 


السطر 74 : نقوم باستدعاء الدالة 30ع111 ع06ممعاع]3ع1ن) .. 
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الحقن الديناميكيىي الفص 6 
المعامل الأول نمرر به مقبض التطبيق المراد إنشاء مسار التنفيذ به .. 


المعامل الرابع نمرر له عنوان البداية 0301168500,7ا.. وسيكون هنا عنوان 
بداية الكود هو عنوان الدالة/030116:3|. 


المعامل الحامس المستخدم كاع]23131006 لمسار التنفيذ .. حيث نمرر به 
عنوان وجود المكتبة ا الالالا علي الهارديسك.. والمؤشر له هو600انا. 


وبالتالي عندما يبدأ التنفيذ من عنوان/0301151319ا مع تمرير الوسيط 0115001 
لقان فقسنيؤةع هذ ]| إل تحميل المكسة :فى :تظطييق. الالة الحاسية: 


هذة كانت الطلررقة الأول بمدوشى تس تكدهر هيواث الندانة تين العبذالة 
٠03011319‏ .. مع استغلال وجود المعامل الخامس في الدالة 8981© لتمرير 
مسار مكتبة الاا0 لها . 


الطريقة الثانية ©/81) 006 لا تختلف عنها كثيرا .. حيث تحتوي علي نفس 
الاساسيات.. ولكننا لن نقوم بوضع عنوان بداية مسار التنفيذ علي دالة 
030111319ا وتمرير عنوان مسار المكتبة لها .. 


لل دفو شاه ردت رمشعوقر كيفك كو لكل ”تظبيك الالة لكا شمة د اليقور 
الكود بتحميل المكتبة بنفسه. 


13 0 


الحقن الدبناميكى 


> - الطريعة الثابية.س6 2 





نقوم بعمل مشروع مشابه للمشروع الأول باسم [10(666002 ااط] به زر 
باسم [8113/_1011801] سيستخدم لعملية بدء حقن المكتبة دخل الآلة 
الحاسبة. 


داخل الملف [17[6©11011.105 اانا] نضع التعريفات التالية : 


عاكلا كتتصا ابت علعباأ1 1 
عطلاكتاعصدعها علباعص 2 
عدا 2ت عدبا عباعصس1 3 
عاطا دعصم ععبناعمدت ك 
الاكة. ص عق تفط عقخصمتء 3 ركخصط ةنا ععبلاعص 5 
م 
طال 2تأعصعها طاتاعلساعصس ؟” 
طثا, 32 ,عدبا طاتاعلساعص1 5 
كازا 32 اأعصصص طاتاعلفباعمرت ه 
لا1 
ا ان ار ا ات 1 1لا نا لكاااك: لاآتاليط عصءنوانا 11 
12 
211. 13 
1ل يالوت 1تاناائإنا_ناناًا 14 
1لالا! لاوم [اعل"ا[_لكاا8 15 
ليل ليل اليل لاي اليل لي للد الي ليل الل للب للد لي لاد ال للد ال ل لود ل للد ال للد ال ل لو ل ل ل 7ر15 
2غأقل. “1 
لاى” اصع تانادات_" حال عاغ1 1 صلاطك 13 
لا,"أأك. لانامكا” حال 002 دل"ااانا 13 
نار "اأضع 3 اعصعدها" دحال اإصصرعها لات 
لار"ثث؟ 3 اطااكةص ا" طاك طناةةصا 21 
ست 
لا لك 3:1 أد_تغةناطالااة ‏ 23 
لا 0 كطالاكددا_تغ3ناطلطد 4ت 
(لا) تزبال ذذكخ حال داغأدص اانا_د]أةناطلط 5‏ 5ت 
لا لل ندع_دغدناطالاد ‏ قت 
ل ل ليل ليل الله الي ليل لي للد الي ليل ليل للد الي ليل لله للد الي لي للد الي ليل لي للد اليل ليه ليل ليلد لين لي لل لي ل 4 لل للد لج 230[ 00 لدنم 
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ا ا ا ل لا ا لل للد ا ل للد ا ل ل ل لإ لا ل لإ لا ل لإ لل ل لإ لاد ل لي ل لي ل ل ل ا 





37 3ت 


1 عدامت1أعصاط 29 
00 اإصصعة»اط 30 
ا قاط 31 
ء 31-13 32 
00 ععادة]قناطلطه ‏ 33 
1 اعفد تناطلاات ‏ 34 
ء عماطعكد_اطالات ‏ 35 
ا الاعشع و2 صاطلط 5‏ 35 
ء محعرط | سشعلم 375 


قاس 
- كت 


المتغيرات الجديدة هي : 


السطر 26923 : هذه المتغيرات لن تحمل أي بيانات .. فقط موجودة لتحديد 
حجم قطعة البيانات المراد حقنها..عن طريق فرق الإزاحة بين الأول والأخير. 


السطر 24 : 
السطر 25 : 
السطر 33 : 
السطر 34 : 
السطر 35 : 
السطر 36 : 


متغير سيحمل عنوان دالة/ا1131ا0301ا. 

متغير سيحمل مسار ملف ال اانا علي الهارديسك. 

متغير سيحمل حجم قطعة البيانات المراد حقنها. 

متغير سيحمل عنوان حقن البيانات في تطبيق الآلة الحاسبة. 
متغير سيحمل حجم قطعة الكود المراد حقنها. 


كير سيحمل عدواتن حفن الكوة فى تطويق الالة الحاسمة: 
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وشفرة الملف [1[©6]10102.8517 اانا] ستكون هالتالي : 


3., 
اعقهمم مصعم غلط 32 أأقعلذه ,خأداا أعلودن. 
عم أفمعةه عدت 1118 تإقتلاة5كهع ١الملاترتن‏ 


عتلا تلد ععزت1 اانا ععبناعضا 


ع200. 

:1ت أادك_عاده_احااات 
أقات_دناة تناطرعك دع ددع3لكت ؟ [ك+ ترعع | ترجاع جمدم 
طنالةقضا_ةئعةتطرطة أن ججمعء0لم ‏ [43+ ترطع ل ترحطاع جما 


مدع للم مق ءطنالقها - يزمع ر زترطاع |رمع سمدم 
داأةطالان_دئةناطرتك أت و5دع:للم ب [4+ تداع | :<«ماع جما 
طق اان_دعةناط نمك داوراظ , #زتاع تأدبام 

ارق رطأ اقصا اأقا : تدع اادء 

اعم 


:توع_عادد_احااات 
:اه 


اال_الكارعادصدتاعانعد “لاعت ععاوسجنر 
عددات أكصآط بوكر 


داص اخلط اخنطتمتخوصص تلض ععامجنر 
باح ءناوانا العلعق, تالكا 1 جات اك[انا_نانال ععحة أ حصتط ممق عوط زمعومادانا ععامجصر 
الالال" 
لاردكوععم ]برع ععاوسدرر 
ل ليلد ل ل ل الي للد الل ليل اليلد ل الل ل باد للد ليلد لول ل ل ل ل ل لق ل ال با ل لق ل ل ل ل ل ل لي ل ل ل ل ل 7 
كارت رت د _: حرق قط امات ارت د بابا: ركرك بن 1 115لا ود ا« انار نال تتح مإشاط عصنام عم وان 
دا “الا, “تع اودر 
تانااك]نا ١‏ 1!1_امأبتفاح ديوع 11 


نالكاخ ل" إنانت_امأبتتح دبجمع [زموات. 
[رمةدطاث نام ممعي بجع بعسودم 


1533 


| زم] انا صلرى لطا الا له للا لكك 


كم كخم ]م كخم كم | كم غم كل 13[ 17 آم | لم خم م 3137| دا 17 انم لنذة لمظ امن اذك 
لا ممخم وم إنا صلم لا كا [س- للا كلظ لذ صخ مخ زنط صلم كلا اكلا لس زا كلظ نأا صم ومع وبا 
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أت عونت تام عويب جلاع بععصسووم 
م1 ا_لذاطح دجزامع 11 
21(ا"ا]_لذااقح ديرزوع آل 
أععزت] ااه 
[ألاعء. 
[اللاعة. 
كنا ان_امأبتباح دبجزهع [زموات. 
لارط لاطا وداد تدع ععامسوصر 
عداع. 
عكاث 2 نجع مولن 
اعم 
[الاء. 
علائا اردع منورمر 
آعم 
تراجرع عمعدوانا 


انام أدعزك]1 
اإعصععها «لعلعم عاتصدداع اعد سكعت ععاموبجن] 
تمع أعم عاط حولم 


طاناقتصا لماعم أعمصخاط ددع مقعم طعي عجاوبن]1 
6, حالااتصا_تغدناطابة لمكم 


أدص اانا_تطتتناطبطك لماعم ا قط_عزف امل بتتحاعع أناغخصع نواعت عيعاموجصر 
عد0ةل"ااانا “العاعقمحاءتص اانا_3أقتناط للك «العاعقخدع ندا ععامجسر 


:عأت_التماع 
عا | صانتا لماعم انالك ماعط امع ععجامبسن[] 
د دبزوع 11 


2لا اغا حي .عاق عدر اص عاباص؟" 1 [ ام ا لالالكاى؛تمععودددعل"] عيعاوين 


لالذاطط_ط “ام ا تالكا 
زالذانا- حدجوع 11 
اعم 
أأملاة. 
أشاا نا ل ابتبانلاد_بتباطرل عبنت دات_ )| 1 | ارعصعطمابت عيا مينر 
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نذا كنا آنا ذعة لبا انا 
حطلر لا اكلا [- نا للا 


كل 
نا 
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لات -- بجزهع 11 
ب("عاقع عطاء ضباتر غصص دابا" 11 [ ا لانالكاى“«تمععودددعام عجاوبسنر 
لالذاططة_طا"“ا, | تالكا 
آع 

1الالزة. 

أت العا تزققاز 
أاللاعء. 
عات العلعق همع ,لعزممععد :معدا | تمدص لاعن ععاوجدنا]1 
0[عاق ارلا كوع ات_ ااش_كدع اط ودجمعع وم تامعمن) ععاوسن]1 
تمع عات_اطا لولم 


بعلم عطع ومعت ,مع ععممه ععدعدااةر 
فصع_ععص تطللطد أع؟ ]آم عداكدع وم احابة عملم 
أ ةأد_ععد_اتطلطد اعة ]ام ععإحعوعت_اطاللاة تألاة 
111 ماعل عماطع وص _اطاباات, ا الالكارعاقتطى؛#«ععصااشاقبطئثة ععاوسن][1 
ع|]#الاتناشطظ_ع الااع ماع_عارامم 
لتق اااعشع وم احاباة ملم 
, تابقع دح _احال تع أة احا“ تصممع «أدجعع ونام رثا عجعاوين] 
االالكارععاطعوم خبطت :قاك_عاعص_تطلطه أعع ]آنه 


قعاقنا غطع ومعوض عم] ععهممه ععأقعدلاة 
تحط_تختناطلطه أع؟1[1آامرععادةدنانابااة متملم 
أأقأاك_تاأتناطبطه اعمس ]1[ مرععادداتناطلااة تألاة 
111انات_أماع اما ععاكة 3 ناتاناات, ا اتالكاربءاقتطىء“تععدااشاقبلئث؟ ععاوسن]1 

ع | 1[ ارات طط_حاوابت نم 
تع اتقة أ دناحا لات لتضلر 
, العلعت تت ناط راكع أة كط ”؟ نصممع | «أادجععء ونام رثا ععاوبن]1 

ا الالذارع 35 ةناتالاائ, 3_513:1غأةناطللاه أع؟ ]1 [أه 


نقععط! ععصوعه عطا عامع ار 

, لعشت 3 ناطلالاى, اعقعادد _اطلا كرتا تار عأة حار ءمعرط | عتصمرع عع احص رن ععاوبدنر][1 
لاملا 

تمع تدععحا | نعل" سوملم 

لا <! أعقعرحا | دعل" 11 


1325 


[ل- [- هد هد [3- 
ذنا لذنا طلم كلا كلا 


دنا ذلا للا نا لنة ا لقا ا للا ا كلظ كلظ كلظ لظا كلظ لكك للا 
كا اتا 3ه للا لط نأا مخ زع زعا طلم كا كلا 


سق 
- دنا 
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ل دلا" ١‏ | ع | ابل" تمأ ععزت1 اانا" 11 [ ام اال الكاى#مععوددجومامن عيعاوبن]1 103 
االالكا 14 

عدععحا | بعل" «اأعلعم عادمصدلاعكداءت ععاموبجن] 105 

بععأكععماطلطم, اعاعفعوم تطبطه املعم عات مط ععدع ع ادبلطذ ععاوبجن]1 1 
عطشع اعم_امحاس] 11 

بعداكة]ةناتانااتى, اتاعكفةأتتناطبطه املعم عات مط عتعدعطادبط رذ ععاوبجن]1 10 
عخطشع اعم_امحاس] 13 

أاعداح. 1110 

ا الالكام اال الكارز" تطااتع حصا ععرض]" 11 !ا ا انالكاى نم طعوددععمامن عجاوبن]1 111 
[اللاع. 11 

آعم 113 


تدع أععزم1 114 
+11تأه قاع 115 


سنعود لشرح قطعة الكود في النهاية .. حاليا نستكشف الشفرة الجديدة 
داخل الإجراء ]1[©6. 


السطور 55-54 : نقوم بالحصول علي عنوان الدالة/ا1131ا030 ١‏ ونضعها 
في المتغير 03683_1030110آ0لاأ5. 


السطور 58-57 : نقوم بالحصول علي مسار مكتبة ال الالا علي 
الهارديسك ونضعه في المتغير ]23 ا انما_0313آاطلاا5. 


السطور 81 -87 : نقوم بحجز منطقة في تطبيق الآلة الحاسبة لوضع قطعة 
الكؤة بها تقوم أولا عسات حخفر الكوة تطرخ الاررحات. ونجحب استخدامر 
الترخيص 5آ811//ا0م2ه_ع1لاعغلاع_ع6ث/8 .. وإلا سيفشل تنفيذ الكود .. 
وفن نكر تقوور بكنانة الكوة فيلك المتطقةي. .رن عتوات رذانة الكود. 


السطور 96-90 : نقوم بحجز منطقة في تطبيق الآلة الحاسبة لوضع قطعة 
البيانات بها .. ونقوم اولا بحساب حجم قطعة البينات بطرح الإزاحات .. ومن ثم 
تقوم يكتابة البيانات ,. وتخزن هنوات بدانة السانات. 


السطر 99 : نقوم بإنشاء مسار تنفيذ في تطبيق الآألة الحاسبة وعنوان 
البداية هو عنوان بداية الكود .. ونمرر له المعامل 50103538001 والذي به 
عنوان بداية البيانات(عنوان 235 اانا © /إ030115131٠)..‏ والتي سنستغلها في 
الكود. 
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ا 06 1 51 
033_5131اطلا5 مأ 800155 , [4+م5ع] ,ردطهة مدهل 
03010ا_03]83اطلنأا5 05 5د5ع8001  :‏ [4+مطع] ,رمطهةء دهء1 
٠0301161319 15‏ - لاقع , زططع] ,رعتدء مك1 
أ83اارما_ها03اطنن5 05 و5د5ع8001 : [4+مطع] 


,#آط© 3»ع©١‏ 


220 اارما_383ناط لاد اولاط , © 152ام 
103011131 ااه , اه 5311ء 


266 
5 0 


0 040 01008125 1ن 5 
0 040 8م ة 16 :مع نه ناطي 2 5 
لصوا 56 1ت 2 101152 :68 5 نا طن ا 5 
0 040 0- 112133 5 





عند إرسال عنوان قطعة البيانات 036]38001آلأ5؟ ك 5231311666 سيؤشر 
مؤشر الاستاك م5© علي تلك القطعة .. 


حيث سيكون [6©50+4] هو العنوان إلي أول متغير غ05038_5131ا]أ5 .. عندما 


نضل لهذا العنؤات :تستطية تخديد.حمية المتغيرات: التالئة :بإضاقة الإراحة 
المناسبة. 
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> الطريعةالثالئة منت ,عير 


سنستكمل هنا الحديث عن ال 10015 .. فقد تطرقنا لهذا الموضوع من قبل 
ولكن كان عن ال001لا اج0ا لمراقبة الأحداث الداخلية في التطبيق الحالي. 


من الممكن أيضا أن نقوم بعمل ا00لا 5677056 والتحكم بالتطبيقات الأخري 
والتغيير فيها .. وفي هذه الحالة يطلق عليه»امهلا 06آ/الا. 


عندما تقوم بعمل 001ل ١0|‏ فيقوم النظام بتحويل الرسائل إلي الإجراء 
العمجود ببررافتكك لقلترة الرسائل: 


ولكن عندما تقوم بعمل 1001ا ©10//ا فيجب أن يكون هذا الإجراء بالإضافة إلي 
دالة تثبيت خطاف الرسائل “«ع|17001/51100/ا/اناع5 .. موجودان في ملف اانا 
وستعرف لماذا ؟ باستكمال قرءاه الموضوع .. 


تأصصط لمعطضائعل -ضم القع ااممة ضق 5||!قأكضا ضمللأعصضلة #اعاعاه هل أع تحمل درالالائع 5 عو ا 
ما ع لاقع مام عاصمط 3 5ق أكضا تنماأةع ااممة ضكر .لراقطاع عادصمط 3 مأضا علالعفعمم 
31ت !افع مام عإصمط كر .5 أرعمئع أم كعمننكا تلالاقائعع لدأ مزع اموه عطا أ)متاصممم 

5 عاطأ أأة طلشئ زه معطا عالاصعمة 5 طلاتت؟ نعطازع معأةاعمدعة عتأفعننع امأاصملم 
تلضااع خلا عام ملأعيتنه لون الالااع 5 عطا جمعلع دأزعمناك تلماأعضلا قلط | .معامؤة علطا ما 


) #اعاعا مه لأكيتدن )1( الالااع 5 كان لاما 


اأقأكضا ما غاصصطا أن عونا م 111ا 
عالاقععصام عاصمط أه كمع لملة م ال الالال الاقار 
5138| تاملأقع ااممة أمه عاتضقط م ودنام طأ الت | 15لا 


انأ عأصصط اأقأكضا ما مقعغطا أه ثم الاصعلن م تانح جمم ان للا نا اانا 
:1 


للدالة 4 معاملات .. 


1 -الأول 10414001 : يحدد نوع خطاف الرسائل المراد تثبيته .. ويوجد أنواع 
عديدة نختص منها بالذكر التالي : 


٠‏ ©2106هاثآلالا ا امح_لالالا : تثبيت خطاف رسائل يقوم بمراقبة 


الوتحائل الرسائل قبل اتا برسلها النظامر إلى إحراء الناقزة 
الموجهة إليها. 
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ء 85120255[ الالالااه6_لالالا : تثبيت خطاف رسائل يقوم بمراقبة 
الرسائل »بعد أن يعم معالجدها من اخراء الثافذة الفوحمة اليها: 


81)_لالالا : تثبيت خطاف رسائل يقوم بمراقبة رسائل وإشعارات 
مفيدة لتطبيقات 281 أو 11310150 83560 /)عألام01) . . متل 
رسائل (بدء تفعيل نافذة وبدء إنشائها وبدء إغلاقها وبدء تصغيرها 
وتكبيرها وإعادتها للحجم الطبيعي وغيرها مما يفيد تطبيقات 
81 في توجيه المستخدم). 


ء 6لا888_لالالا : تثبيت خطاف رسائل لتنقيح إجراءات خطف 
الرسائل الأخري. 


ء 89ثم80قلا2»ا_لالالا : تنبيت خطاف رسائل لمراقبة رسائل ضغطات 
الفقانية: 


ء 0585ا140_إالالا : تنبيت خطاف رسائل لمراقبة رسائل الفارة. 


ويوجحد غيرها العديد من أنواع إجراءات خطف الرسائل .. سنختص في هذا 
الجزء النوع (0/11تظلاع>ا_1/الا .. والذي يقوم بمراقبة ضغطات المفاتيح .. 
والذي يستخدمه جميع برامج /ع000 الإع»!| المعتمده علي 001 7(عاولا5 .. 
والإحراء الخاص باستقبال رسائل الخطاف هو ©0302]06طلإع©! وسنستعرضه 
بعد قليل. 


2 -الثاني 11م1 : يحدد عنوان إجراء المستقبل للرسائل..وسيكون عنوان 
لإجحراء نوعه 030802طلإع)| . 


3 51100 : مقبض التطبيق الحالي المستدعي للدالة .. والموجود به 
إخراءخطها الرتعارل .:وتسكون "قف .هته الخالة :مقيض تطبيق إل 
اا0. 


4 -0/10062014 : تحديد الثريد المراد تثبيت الخطاف له .. إذا كنت تريد 


تثبيت الخطاف علي تريد محدد .. فقم بوضع معرف التريد هنا .. واذا 
ا أن يتم تثبيت الخطاف علي جميع الثريدات فقم بوضعاالالا. 


وعند نجاح الدالة فتعود بمقبض إحجراء الخطف ©83001آ 5001 .. والا ستعود 
بقيمة االالاا. 

الآن بعد تثبيت الخطاف واستخدامه وانتهائنا منه يجب أن نقوم بإزالة الخطاف 
بواسطة دالة “ع1 5001/5100 أ/ا/ا>0001اصلا : 
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تاها 3 خعنند تتعء ترصراع فرط #رعاعا ون لاعيتدن ل زر اللاع|امونانرلا عط[ 
#اعاعا مهو لأعيتده اع درا لالائع 5 عط نط صلقطع عاصصط 3 قا لعاأقاخصض عءلنععءمم 
ماهلالا 


!»عام ها أكوتدمل نر الالاعامو تارونا اناناق 
عتم مزرع؟ ما علانععمم عاممط أن عالصعط م الاكاياد 


م 


المعامل الوحيد لها هو مقبض الخطاف .. وعند نجاح الدالة تعود بقيمة غير 
الصفر .. وتعود بصفر إذا فشلت. 


ونتطرق الآن إلي الإجراء ©031051:0طالإ1»6 والذي يستقبل رسائل ضغطات 


لت عتتاآع ل -قرد لاقع | امرمة قلق ذا علامعفعهم عاممط عم "ارده تابزع كا عطا 
اصلأقع اأممة صق ععبنع معطته ذاالوقع ضع اموه عطا مملتعصرطة عاععطاادعء لمعصئع ل مترجةءحارا 
نزةصطائزع عا 3 ذا معطا قضة تملتعصلة عوجععع الالعامع 8 عم عن مععع اللاع دا عطا دذااوت 


.لاع 5 85 ع ملم عط 10 بأخا اران لا طعا_ابابتا رن نالا عاعا_اسانكة) صمةددعمم 
اعم نال ردعتدابرع خا خاناتظ | اكذا 1 الاذغ]] ا 


عنمع باصملا م كوحت 111ا 

ممع مرععا-ا دللا م بك مغر الالقنام نا نايا 

لملأة متاصاضا عمقفقدععمردم عاد امع ما م سحت م االقنام0 | 
م 


المعامل الأول 6006 : أو ما سيصبح ©5600 لأن الرمز ©00»© كلمة خاصة 
في الاسمبلي .. وهو يحدد كود يتم استخدامه من قبل الإجراء لتحديد 
كيفية التعامل مع الرسالة.. وياخذ إحدي القيمتين التالييتين: 


ه 2611010 6 : يحدد أن كلا من المعامل الثاني والثالث © مقطا 
310" بهما بيانات عن ضغطة المفتاح. 


ه /م020101١_عل‏ : يحدد أن كلا من المعامل الثاني والثالث© 0ة3هننا 
30 بها بيانات عن ضغطة المفتاح ولكن الرسالة لم تزكل 
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من صف الرسائل .. بواسطة استخدام 1655306/)اعع6 مع 
الراية غأ/01/ا1012_الاط . 


وإذا كان قيمة الكود أقل من الصفر .. يجب أن يقوم إجراء مراقبة الرسالة 
الحالي بتمرير الرسالة بدون معالجتها إلي دالة »“6ا16«*6!100١|31©‏ لتذهب 
الرسالة إلي إجراء مراقبة الرسائل التالي. 


حيث إجراء مراقبة الرسائل يتم تثبيته داخل حلقة لبعض أنواع خطف الرسائل 
ودالة «001)6 311١16“‏ تقوم باستدعاء الإجراء التالي في الحلقة. 


وبالتالي إذا لم يتم استدعاء دالة ‏ “06و »|0ااج> .. فلن يقوم النظام 
باستتدعاء الإجراءات التسنابيقة: للإحراء الخالي: 


المعامل التاني 5313173لا : يحمل قيمة كود الزر الافتراضي لعا |1]03آ/ا 


0006 .. والجدول التالي يوضح بعض تلك الأكواد وقد نزعت منها قيم كثيرة 
وستجد الخدفل الكامل فرفق معرملفات الكنات: 


عبااج/ا 51112011 

١ 5‏ آنانع»ء 031:0 طلازععا! 01 عونان للا («<©1) 0115153111 

00 لاط عدناممط أأع ا 01 لا0 1 آلاظا_عكا/ا 

0م ]لاط عدنامط أطو 1لا 02 10 آنا8ظا_عكا/ا 

5510ع060م كعاقعط 0001م 03 امه _عا/ا 

(ع05ا00 لثامأغأناط-ععطط) مم أغأناط عدنامط 1001لا 04 101 آناقاالا_عا/ا 

ع 5لا 0ل 71 :2008 /153/ا/2003 /12/ 2000 10015 1لالا 05 1[ [آاناظعا_كا/١‏ 
م0ماناط 

ع5لا0م 72 :2008 /53آل/ا/ 2003 /2000/1765 106005 1لالا 06 2 6 آلاظكا_كا/ا 
لاط 

لمعم لقع لملا 07 1 

لاع>ا عامط ككا نم8 08 01 م8_كا/ا 

لاع>ا 8م 1 09 168 _ا/ا 

لاع>ا //لا0 خم [طاعا 25 [1عاعا_عكالا 

لاع>ا //1 8510م ملا 26 مزنا_كا/ا 

لاع>! /ا/ا 10م 10111 27 10_عا/ا 

لاع 0م ا لاما 28 الا 0 نا_عكا/ا 

لاع>ا 11م 2 الس1ط_عكا/ا 

ع3| 300 3.0 5ئنخثا هلط أللا عهظ بلاععا لاع عحان50 1(1هم 20 2507 > _كا/ا 

لإاع>!ا 1/5 210 521 ا]1_عكالا 
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لاع»! اعم ع2 ع 1غ اعصط_كا/ا 
لاع»ا ماعنم ع2 ماعس_كانا 
لاع>ا 0 30 0_كا/ا 
لاع»ا 1 31 1 ا 
لاع»ا 2 32 0_2 
لاع م 41 هم_>ا/ 
/اع»| 8 42 8_كا/ا 
لاع»ا © 43 ©_كا/ا 
لإع»ا 1ع 0م 1 كا 
/اع»| 2ع 1 2_كا/ 
/إع»| 3ع 72 3 _كال 
لاع»ا »ا 0 الانالا 90 >1 1-0 "انالا_كا/ا 


المعامل النالت نرج:جط! : مقسم إلي بتات بطول 2 بت وتقوم بتحديد 
العديد من الأشياء في وقت واحد كالتالي : 


البتات 0-15 : تحدد عدد مرات التكرار للرسالة .. والتي تحدث نتيجة 
اسم عا المستخدم علي الزر .. حيث يقوم النظام بزيادة العدد عندما 
يتم توليد رسالة ١//2/001>ا_"الالا‏ أسرع مما يستطيع البرنامج أن يعالجه .. 
حيث لا يتم توليد صف رسائل من الرسالة .. بل هي رسالة واحدة وبها عدد 
مرات التكرار. 


النعاق :16233 كو القحصن نهو قرهة م وولف ا اين الكبرورة فيه الما 
يمكن استخدام تلك القيم لتعريف الأزار .. ولكننا غالبا نستخدم /(6-ا لانن 
65 لتعريف الأزار. 


البت 24 : يحدد إذا كان الزر ممتد أم لا .. الأزرة الممتدة تكون أزرة الوظائف 
اأطكرع ممه 1ع وغيرها .. وأزرة لوحة الأرقام 177230ئالا .. فإذا كان قيمة البت 
واحد فهذا يعني ان الزر الحالي0ع2«“]6070 والعكس. 


البتات 25-28 : محجوزة. ' 
الت 29 : إذ] كان قيمنة واخق فهذا يعدي أنه الود كام مضفوظ لأسفلن 


والعكس. 


البت 30 : يحدد حالة الزر السابقة .. فإذا كان واحد فهذا يعني أن الزر كان 
مصغوط لاسفل قثل إزساله السالة:. واذا كاف :حصفي فهدا هدي أن الررطلا: 
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البت 31 : يحدد حالة الانتقال للزر .. فإذا كان واحد فهذا يعني أن الزر في 
حالة ضغط 0010/5 5010 .. وإذا كان صفر فهذا يعني أن الزر متروكمنا. 


علدت تكدد 1 دكمرعوع م 


2:1:0]25]241-1251241291- 8151-5 





أضناصع أمعمعر بع ا ودا] بعنا١‏ لعل معامع ا علمع امعاصممنا 
وذا] عاماء-بعها عبماسعم 
ددا عأقاع-صد) لعصة ]| 


والآن بعد استقبال بيانات ضغطة الزر ومعالجتها فيجب تمريرها إلي إجراء 
المراقبة التالي بدالة“«6)اهمه »ع لااج. 


وقبل أن نري كيف نعالج ضغطة الزر ونعرف المفتاح الذي تم الضغط عليه .. 
نقوم بمعرفة ما هي الدالة“«1001“</اااج اولا .. 


عض عطا ما خنصالة كترماضا عامصط عطا معمكعقم تلملاعضلطة #اطكامه1لمكيرع الألاهنا عدا 
عط كعلع ماع ملات لاماأعقلا قلطا .طاقطع عاضمط أضعضناع عطة ضا ععتععمرم عاصصط 
تنضااء صلا عمرطعاوه لاأاعنا 


!»ااعامه اهدع | ااتنا ١‏ الاذغ]] ا 


تأدصمط أصع صنت ما عانمصوط م ل اراد 

عالانععمرم عاصصط ما ع5 5وم عنمع عاممط ثم ا 11لا 
ع الاق ععمزم عاضصصط ما لمعه 35م عنااةم ثم لمحتن اكرام داريا 

بعالا ععمزم بعاضصصط ما لمعه 35م عنااةم ثم سرحت [القنامن | 


وكما علمنا فتلك الدالة تقوم بتمرير بيانات الرسالة إلي إجراء مراقبة الرسالة 
الالفدن بحيية رمور :قي المعافل الا دل مقيض القوك الخال نوناق 
المغاملات التلاف تمر دهم السالة كها تفى. 


© معالجه ضربات المفغاتيحخ518:0165 لإع»1 51110و5ع©220 


الآن لدينا كود المفتاح الافتراضي في (/1//5313 .. ونريد أن نقوم بتحديد حرف 
الآسكي الذي تم الضغط عليه .. مع وضع حالة الوظائف الخاصة مثل 6855 و 
لالالاا و51 و تحديد لغة المستخدم الحالية في الحسبان. 
يوجد دالتين تساعدنا في الوصول إلي حرف الآسكي وهما : 
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1 -عغ030526للإعكااع0 





10/856[1- 2 


أولا : 6غ3:015621وطلزء»! 66 
وتستكدمر لنمية!اتخالة 56م هماع لغوت يكنهيزة كف زادت: 


أقلللناك؟ طكك علا1 أت كلاأقأ5ت غطا كعامصت تاملأعصلا؟ عقه51 هه طابزع كلاع ما عطا 
لاع ]لاط مع اأاصضعمة عط1 ما عنوع ما 


أمع1 هتذل اده تابزع لاع دا انانا8 
3 5لاأةأ5 عمتافعع؟ ما متقكرة أن ددع للق م ات نات كلم ع 1 انم 


| 


حيث المعامل الوحيد للدالة وهو ع]5]3لإعام! يشير إلي مصفوفة بحجم 256 


إذا نجحت الدالة فتعود بقيمة غير الصفر وإلا ستعود بصفر. 


ثانيا : 1085611 


تقوم الدالة بترحمة كود المفتاح الافتراضي مع حالة المفاتيح الناتجة من 
استدعاء الدالة عأ603:051/إع6©11 لتولد حرف الآسكي المناسب. 


ضة عنمع منععا- اقلا اث نع الأاععمة عطا ممق ا عق قمالأعصضلة األععقظه |[ معطا 
ان لص1ت قلاع عند ل صااة وضاك ضمم عع رمع عطا ما 51318 روم طاوع ها 

ألامزضا قلطا قطاكنا عقمع عغطا عمق اعضقا صمااعضلطآ عقطا .كععاعهرو لات 

اعماق عغطة خط لعا لاضع ١)‏ ألصنقا لنقمطاوعها أقعاك ولام نصة عنقةنلاقمقا 
.عالضقط ألامئقا روم طاوع ما 


) اأععذه | آنا 

0 وباك اه [ ااانا 
2001 هدك مر بكتدم امد ع حب 1 لاالا 
3131 51318- زع ها أم 3001855 مر 1ت أحارات كرما ع 1 لأزن] 
لاما م318 اكلة؟] ؟دآ زع أأنان ثم لماص اغا ناس | 
18 لاطعم دق مان 3 ثم كد 1لاالنا 

م 
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المعامل الأول لإع1]1آ/انا : ونمرر به كود المفتاح الافتراضي. 
المعامل التاني ©5630000نئا : نمرر به كود الفحص ويمكننا تجاهله. 


المعامل الثالث ١019/5216‏ : مؤشر إلي مصفوفة 256 بايت بها حالة الأحرف 


الففامل الرابية556 186 # فوفس إلى .مكوث تستفيل جرف الأسكي الناتة: 
المعامل الخامس 1305تانا : راية تحدد هل القائمة نشطة أم لا ونتجاهلها. 


عند نجاح الدالة تعود بإحدي القيم التالية : 


القيمةه صفر : وفي هذه الحالة فإن كود المفتاح ليس له ترجحمة .. وتحدث 
مع [بعض] مفاتيح الوظائف . 

القيمة واحد : تم نسخ حرف الاسكي إلي المخزن36ن0م|. 

القيمة اثنان : تم نسخ حرفي اسكي الي المخزن]3دانمم!|. 


©) داله 111001 لا/0101101 0ع:6©110 : 


تستخدم في معرفة مقبض النافذة النشطة حاليا علي الشاشة. 


علا له عالصقط عطا كتتتلااع؟ تتمااعضلة تحمل ذرالألال تسمدوعمه طااع جا عدا 
لاقع الات 5ا زعكلنا عغطا طأعلطه تلض منخن مضت عط نكن لضات؟ تنام رقع دآ 
لقعنطا عطا ما تتتصائم تعطفاط ولأطمالاك 5 كضقامعة ضعاعجوة علطا .زعصضاعا'دمب 
5لققغطا تعغطاه ما كععمل ١1‏ صقطا نمل صائتة لضندء نعغمآ عطا معامعنت أقطا 


إناانا نا انتمل نر الالال تسمروعمه ااع دا انان 


حيث الدالة ليس لها معاملات .. فقط يتم استدعائها وتعود بمقبض النافذة 
النشطة. 


©) داله 111001 لا/ط1101ن01: 0ع:6©110 : 


ددنت م في معرفة اسم العنوان 1112 لنافذة ما. 


145 


الحقن الديناميكيىي الفص 6 


نع األععدرة عط أمه تتزع] عط كمع امرمع تداأع صل جرع [ تحمل نر الالااعء دا معطا 
نان ل ترات لعا أاععمة عط ا ع أالاط 3 فاضا زعصضه عقط 1 ألا قط علألا ع “ندل انث 
8 انرمع ذا اأمنتاصدع عط أم أتزع1 عط اماضمت قه ذا 





)اع |[ يعدن ل ذرالالااع دا ذا 


أناع] لاك امناصمت عم متنه لصتت أ عانصقط ىم وملام لا انان 
أناع] ندا إعأآلاط أن 5ددع 300 م اس 15114 0 | 

لأمرضع صا كنم اص قزق لاك أن عع طاصالات الالالال لمر ابا ابتك ام 111ا 
١:‏ 


المعامل الأول 50/الاط : يحدد مقبض النافذة. 


المعامل الثاني ١0511150‏ : مؤشر لمخزن يستقبل العنوان. 
المعامل الثالث +01013601001 : أقصي حجم يتم نسخه للعنوان. 
الآن سنقوم بكتابة ملف ال اا( وسيكون باسم [ اا !100] ويه الملفات 
التالية : 
[ماكث. لاما 1001 !] 
[أع0ا.ااما 1001 !] 


ملف التعريف [!©0ا. اانا >»11001] سيحتوي علي التالي : 


الاناكاوم0ط /7ا/ 18 ا 
]| 


1521١1001 
31|!100]ك ناملا‎ 16 
عط 00ت‎ 





بينما ملف الشفرة [48517. اانا »11001 سيحتوي علي التالي : 
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25 1 
اعنهمم ممعم غئط عت أأقعلطه ,غأهاا اعلنصرص 2 
عا افمعه عدتع ‏ 11116 للتالاعق 5ه 11011 نزم 2 3 
3 
كلل ناماع لات علعبااع1 5 
عضا 2ت زعكبا عأساعم 5م 
عطاك تاأعديعها علساعصم1 "” 
عطاء كخم عهعبااعض1 تخ 
ب 
مثا 32 عدبا طاتأاعلباءض1 10 
طلا 2 23اعصنعها طتاعلباءعس 11 
حازا عتتاكخمر طاتأعنساعمد 12 
1 
لاقة خط اعة ل أذد عاقلا 32 اعختطلا:ع عمبااعض1 14 
1 
01151. 15 
ذالاك + لأعطرا_اطابثا بوع ‏ طللاطكتر_ تطخ]ا_الالامك 2 17 
دلاك ع #اعكرا_أملراما باوع نالكاع | لماع_سلع م _ سانا 15 
هخأدل. 13 
لاك ععصةأكصآط ‏ 0ت 
زلا درياك 2 تاك شع 21 
5 
*3]ةل. 23 
00 #اصصلاط ‏ 24 
افا مصااط ‏ 25 
00 عصسضل 1‏ 5ت 
1 
ملم 3ت 
انا انا صدخخص سنك ,عالكات | كل[ : أكصاط عصنمر م أمعاانا ‏ 23 
ل1غانا اانا مص دعص انم 30 
ناث | ا5ت_ذوع_انشقاط_ اانا ح وردودع ك1 11. 351 
أكطآذا تأكلاكز 32 
عات 5د [1ذا مزمنر 0 
[الداة. 34 
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علاما ارمع ماولمر 
اعم 


مرعصع نخادداانا 


بلالا لاانا:صدة نت طن نل غانالالانا:ءعفعصام عمنام عمط ماودلا 


اغالا ل#الانا:ررددندم| 
عاط: لتك إعاة كنم | أجعما 
لات علص ام آل 
اع ]لاز 
انا [ات_نم دا ععصام [أاعواع. 
باع م18[ 
أأللاء. 


ةدنار نجع نودم 
كانانانانانالانات هع ولاح 
لااجزهع 11 

اع ]1لا[ 
أألاء. 


تمة قطاى حمة خط ععءصتصرعاصمتاطر#تععاوم ل لنيعل"]ااد_) مياسن 


تداع وزأ "اطاط روص رمع اعت عيعاوبجن] 
اع اتا متوكر 


عاد اكع خا امعمرعاد ك2 تمطمع لاعت عيعاوينر 
لابأأدعقع 'العاعم عاد طعا الللعهرنار صمت تطشن ادعقم | عيعامجسر 


دح بزوع 11 
انالكاع اعزع_تعكم_امابتبار أعص اط عودددع]«اعمعد عياوينر 
دعبب ال, مرت رد داب 
عجع. 
طم _نتعمم_ ابابا أعص ااا عفودددع]«ادمعد عياوينر 
إعحب لال أأعكقت لام نوميل 
أأللاء. 


:ااا 


1018 





ذا 
ا 


ارلا 
1 لا 


لا ذعة كنا انا 
[ل- دنا 


سق 


كلا كلا لاطا كط كا لا كط كا الا ولط ولا اكلا قط ولا الا وق وكا لا 
ذخا ذلا صلم لا الا [- لاطا كلظ لأا صخ 5غ] نا طلم كلا الا [- لذنا للا 
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مع عتدع زوع 1 

تةتزةطا حمكترم مس ععصتصةعامصتحاط #تععادم ل نيعل" ]ااد) ععاميجنر 1 
آعم 52 

مراعدع عمعصط ةايماومم 3 


اغالا اانا عصفتطا عصمنام عاصمل ]ات أدكم1 75 

عصسخحا تأكباتر 9 

اانا ترصن 0 

بعطععط عادصلا املعم نا لخنم تععر_ عت بعيمامص اك نتصاعص تاعمد عياوينر 8 
ا الالكا ععدةلادوص[حا 


نظ نا 


لقع عادمدتاحا ودر 
آعم 
عع عاددلت ]اك ادم[ 


ند تت تت يت 
بم زح 


دنا 
ددا 


1 
كل 


عمناح عادصل ]ات أخصاصرا 
محص لاطا ؛تعام احص كخم اعص اا عاخصطصضنا ععاوينر 
آاع 

تراعجيع عادص ]ات أخصاصنا 

بالأصعاانا عوط 


ننا اللا 
ا الا [- للا 


دنا ذلا 


السطر 17 : تعريف رسالة خاصة استقبال زر. 

السطر 18 : تعريف رسالة خاصة باستقبال زر ممتد. 

السطر 20 : متغير سيحمل مقبض الاالا. 

السطر 21 : متغير نصي سيحمل حرف الأسكي العائد من الدالةأ108560. 
السطر 24 : متغير سيحمل مقبض الهوك الحالي. 


السطر 25 : : متغير سيحمل مقبض النافذة التي سيرسل لها الحروف والتي 
0 لعرض الحروف للمستخدم في صندوق نصي بها بعد قليل. 


السطر 26 : متغير سيحمل مقبض النافذة التي يتم الكتابة بها حاليا. 


السطر 39 : إجراء من نوع ©0310210طلإع»! .. لاستقبال ضربات المفاتيح. 
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السطر 41 : متغير مصفوفة بحجم ‏ 256 سيحمل حالة أكواد الأحرف 
الافتراضية. 


السطور 46-42 : التأكد أن ©7600 ليس أصغر من الصفر أو لا يساوي 
0 __)آ! وإلا فلنقفز إلي الا ونستدعي<«10012])اع/ااااج). 


السطور 52-48 : التأكد من أن حالة الزر لا باختبار البت 32 في المعامل 
0 .. لكي لا يحدث تكرار للحرف لحدتي [ملا © ا/لا0نا ]. 


السطر 54 : نقوم بتمرير الرسالة قبل معالجتها .. أو حسبما تريد. 
السطور 57-56 : معرفة مقبض النافذة النشطة حاليا ووضعه في0(ل/ذالا). 


السطر 59 : استدعاء 030553#طالإع0©]1 لوضع حالة المفاتيح في 
المصفوفة ع]5]2لإاع)). 


السطر 60 : استدعاء 108561 لتحويل كود المفتاح الافتراضي إلي حرف 
اسكىي. 


السطور 67-61 : نختبر القيمة المعادة .. إذا كانت صفر .. فمعني ذلك أن 
المفتاح من بعض مفاتيح الوظائف.. ونرسل رسالة 1( الاع_/7ا2»ا_الالالا إلى 
النافذة لدينا بمقبض النافذة المضغوط بها المفتاح مع كود المفتاح الافتراضي 
ليتم تحليله في النافذة لدينا. 

بينما إذا لم تعد بصفر فنقوم بإرسال رسالة 7_85611ا2>ا_االالا إلي النافذة 
لدينا بمقبض النافذة المضغوط بها المفتاح مع حرف الآأسكي. 


السنظاون 182-35 قبظرة إصراء تقيت الخظلاقف على كمه التريداضي فوفر أذلا 
بتخزين مقبض النافذة الممرر والتي استدعت الإجراء في المتغيرك5/الاط لكي 
نرسل لها رسائل الحروف لاحقا.. تم نستدعي دالة “)امهل اونازهلص لاع 


السطور 87-84 : شفرة إلغاء الخطاف .. ويجب استدعائها عن انتهاء العمل 
مع إجراء مراقبة ضربات المفاتيح او عند إغلاق البرنامج. 


1530 


الفصل 6 الحقن الديناميكي 


نعود الآن إلي نقطة لماذا يجب أن تكون شفرة إلقاء الخطاف وإجراء مراقبة 
الرسائل في ملف لاا والامز هو انك :عندما تقوم عتبيت الحظاف: الموسة 
قاب التظامر بقوم حفن قلف اك ]61 داحخل مساحة الذاكرة فى حمية 


ننثكئانا. 


وبالتالي عند استخدام ملف 011 يسهل حقنه وربطه واستخدامه مع 
التطبيقات الأخري. 


وكما ذكرنا أن كل تطبيق سيحقن به ملف ال اا أي سيكون بكل تطبيق 
قسبهرللبيانات-وللكود مسنتقلين. عن اى تطبيق اشر :: 


وهمًا :تون مشستكلة تسنتهورضها قنها ل : 


عند استدعاء دالة !1075]6/|)100 في ملف ال اا لأول مرة .. سيتم تمرير 
مقبض النافذة التي استدعت الإجراء اول مرة .. ويتم تخزين المقبض في 
المتغير 0/الا١ذا..‏ 

وعندما يصل إلي سطر تثبيت الخطاف بدالة “«17001/5110012//ااع5 .. سيقوم 
النظام بحقن ملف ال اانا داخل جميع التطبيقات .. 

وهقذا الحفن: ؤت على فسيم العباناق تفعدى: ان الببانات النف دمر خرندها 
كمقبض النافذة 0/الا سيتم فقدها نتيجة لإنشاء قسم بيانات جديد داخل 
التطبيقات. 


وبالتالي النافذة الوحيدة التي سيكون ملف ال اانا له مقبض لها في المتغير 
0! هي نافذة التطبيق نفسه الذي استدعي الإجراء 15]3||1001.. بعد 
ذلك سيصبح قيمة 0/ل/ا بصفر في كل التطبيقات..نتيجة لإنشاء قسم بيانات 


جديد بها.. 


وبالتالي نريد أن يصبح قسم البيانات مشترك في جميع التطبيقات .. ولحسن 
الحظ فهو ممكن باستخدام التابع  /5661100‏ . 

ففثلا اذا ارذنا إن يكوث قعص البيانات القيز ونا وقة أسهة ١55زا‏ كقمدم 
باستخدام التابع التالي أثناء عملية الربطوماطنا .. 


1/5 1100لا : لاع | كلاكقناك/ أع95)1!(.0:اعنا/ اانا/ كرودوط.:ل0ا10 ا عغك/ كامطانا 
حيث 5 يشير الي 5661101 553160 . 
ولتطبيق ذلك في بيئة التطوير 5308511 .. نقوم باختيار الأمر الخامس 


[(30).630مع10] من القائمة 5ا|00١..‏ 
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ماعك ‏ مععقة"] مداعمفب ‏ سبكم ]ب عاد" 


1 فاع امامة - 
لامر 5'لاوع 3ا1 عأ"إصمياع كك 


تتمعادل"] 8 
دذانءاأة) 8 





/ لكآ 1 3 تمع ادل" 





ع 1 


وذلك لفتح إعدادات المشروع 1ا©ا00!! .. وننزل إلي أسفل في برنامج 
النوتباد إلي أن نصل إلي سطر عملية الربط انا وهو ذائما يحمل الرقم 3 
ونقوم بتغييره إلي الاتي : 


10/5 :لاع 85757لا5/ 5|ووط.:71011ع55/ علاع.11101١3-7,0,581‏ 
53 "1؟": 1[ شضط18٠/‏ 082:56/ الام/ عأكفغعاعه/ 


لتفسير السطر يمكنك الإطلاع علي ملف المساعدة الخاص ببيئة/30/851] 
في الجزء الخاص بالتعديل في خصائص سطر الأوامر : 
5 ع اذا للاةماطامه ولانأتلع 
فقط للتوضيح قمنا باستخدام : 
112005 5/ 
بدلا من ٠‏ 
5801101[:.655,5/ 


لأن 8111 يستخدم الفاصلة في إضافة علامة تنصيص ويعوض عن الفاصلة 


ب 518 ,. 
الآن.تمكتك ترحمة المشروع ين :ونسية الملفين [االاامامهم] 
و[م“©.-لا0كام10لا] بجانب المشروع الذي سنقوم بعمله في الصفحة التالية .. 
ولا تنسىي: إتشاء ملف التعريق الخاض بتمكنية ل ا الخاصة بنا 


زعطا.|اماكام10!]. 
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انملة 


اقتناصها .. حيث اسم المشروع هو [1001 106//ا] وشكل المشروع كالتالي: 


- مامه كا عل ذل سه 


امه لا اامتعتصادلا تأده لا اأحاعما 
اث | 11!5لكالا 1 10028 الت 15 118110 


10032106 





حيث به زرين لبدء الخطاف وإنهائه .. وصندوق نص يتم يعرض الحروف 
المقتنصة به مع اسماء النوافذ. 


شفرة الملف [©1001.15) ع0ال/الا] كالتالي : 


الال كستم كنات علمبااعضز ‏ 1 

عطاك تاأعديعها علساعصض1 2ت 

عطاء 2ت مكلا عولااعض1 3 

عاضا 32ل أعلصصا عأساعص ك 

عدا 32 ااعحه علساعءصم1ز 5 

عطاء ملكتم ععلااعض1 65 

علا لاناعاددلا عمبناعضز م 

3 

كنات أعصععا طاتاعوفبداعصة ‏ 
مثا 32 ددن طاتاعلباعض1 10 
دا تاعرص طاتاعلباءعة 11 
طلا 2تااعحد طاتاعنباعمصد 12 
دالا 2 كقح طاتاعلباعص1 13 
طلا ااناعادمنا طاتاعلباعصسة 14 
15 
الاقة قط اعة تددح دقلا 32 احعقخصلاع عباعض1 15 
0 
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ات ]1ن ارت لت نا , | لكاا: مالكاشاك: 01ا1ل0اغام عد“اناوانا 13 
ناغانالالانا: لااآلاطظ عا | ستصاعص] “ااأودمصكط 132 

ا انالاانا: لاآلاجاط ]تدا اتمعوممق لات 

ناغانالاانا: لا1آ لاط نع اداعصمد 0 معودممق 21 

ست 

 .)01151‏ ذكت 

لل لاع 1تانلاشإنا_نالنا 1‏ 4ت 

1لالاط! لالع ااث ا ذل"ا]_لذا زع د 

#لالا! لالع الات | 5" لكانا_إذا زع حت 

تالا لاع جانا|ا_ [ناع ات 


لاناك + لأاعكرا_امزنثم!ا باع 
دراك + أعكرا_انمباا بانع 


الاطكتر_ كع خل_الالاما أت 
لالذاع | ط«ط_ كعخل_الاراة ‏ لت 


1-3 لالع _ا لاك 

لاطآ لالع عا 31 

ل اليل ليل الله الي ليل ليل لل ال ل اللو ل ال للق يلد ال لي لله ال الي لي ل ال لين لل للد لي لي للد لي ل لل ل لل 00 كت 
2هخأقل. 33 

(لاأدباك لالاناكت داك عباط 34 

(لاأضربال ددع داك ع1[ صلنبتم ‏ 35 

(زلاأتزباك لاذع دحأك دزتالاكت ‏ 35 

زلاأتزيالك لك دحأك لص اد 37 

لار لابن دحأك عدناسعل" ‏ 335 

نالك صالارمص ‏ 35 

لاد لل ل الله اليل ليل ليله لل ال لي لل ل ال للق للد الل لي لله ل الي لي ل اليل لي ليل ل ال ل لل ل للق لل 73 لال 
*313ل. 1ك 

7 00 ععصةأعصآط ‏ تك 

فاه واناط ‏ 3ك 

00 وصضاط ‏ كك 


ل ل ا اد ل ل ا ل لإ لا ل لإ ل لاد ل لل لا ل لا لا ل جا ل لا ل ل 0 77 7372 22ر4 كك 


السطلر 39 متكير يستخدمر لتكزين مقيض: التاقدة الحالية ى لكي تفارن.نه 


مقبض النافذة الجديدة .. فإذا كانا مختلفان فيتم إضافة اسم النافذة الجديدة 
في صندوق النص. 
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شفرة الملف [520ث1001.6] عل1لالا] 


معفم .2 
اعقو عصموعم علط 2ت: لأحعلط5 ,غأهقا]ا اعلصرص 2 
عا اممعة عدقع ١‏ 110116 ل]تاالا 356 ١1لالآ‏ نزم 3 
3 
عصلء#ادصدلا عوث؛ ععبااعم1 5 
خٍْ 
علام. ”7 
:511 3 
لا1 
ا الالارعاءصدتاعاراعد مامه ععاموسوسر 11 
مع ععداةأكص[طا لمكم 12 
13 
5د تلت _اخلدتصصم لض[ ععاوسنر 14 
ب االالكا, 1 تان اشآنا_ناناآرعدحة كل اطرممةءوطن«:تمعطودادانا ععامسجنر 15 
ا الالكارعمءعوانا ألمت 15 
تاروع عو رط ]ابرع عيعاوينر] 17 
13 
ليل ل الل ال ل لله لل ال لي للد الول لي لله للد ال ل للد ل ل للقي للد ال لي للق ل ال ليل لل الول لي للد ل ل لي للد ل ل ل ل ل 19 
الات 
نظي خط اران ورت رط لت [ إخ1[لا: ود ااا نال" تتلا: مباط عصم عدعطوانا 21 
لت اتنا |: مرةردم| 55 
دا “نابتع مورر 2 
تانااثت[1نا 11!111_ بتاع د جوع 11 اله 
مط تأدباتر 25 
واناذا مرمنر ظخ 
نالذات ا" امانت_اسأبتفح ديبرجع [زمواع. 2 
زمتءتناث تام لمعي ممع بعسووم 28 
[دلووةءدنانث إنامر نميب ججامع بعسووم م 
نا-1 _لذاعق ح ح بزاع 11 لاك 
ااث 1 5ل"1_لا امح -جوع 11 31 
صاكاط عادصدل ]اد اكد[ ععامبجنا 32 
الاش ادال" [كانا_لذا اقح دجوع [أزعواع. 55 
أدص[ |القأخصاصنا ععامسنر 34 
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االلاعء. 35 

[اللاع. 35 

5 

[كق_لاعما_المإتتح- دبزهع [زموات. 358 

كات طارع ا | متخماعض اث“ اوحصك ععجامجن 39 

مات تدان أقحاءدعحدرمق عجاموجنر لال 

41 

بالذاع ايتزع_ناعيما_إمأبتاتح دبزمهع [زموات. 1 

كات طارع ا | متخماعض اث“ اوحصك ععجامجص 1 

حمقءت ع سن اع اأداعع ددا دعحدحرم عجامبنر 4ك 

45 

عكنا_امأبتفح ديزهع [زمواعم. كك 

ددح |التغخصاضنا ععاوسسر 4 

ارك احا وداكاباتصع ععجامجنر 4 

عع 4 

عكاث ار تدع مورن لاك 

امم 51 

أاللاع. 52 

علاماا,م«تجع مورمن 5 

اع 53 

رطع عدءطوانا 55 

ك5 

انا لان :صاسخط عصنرط عاعز | ستصاعص] تاودمصط 57 

احا امع حولم 53 

ملاباايه دا بلع 1خ 53 

لاع دامتبا ات لولم لام 

عا ا صلنكا “الملعهصصتخخطى هنع | نداعم بتاعت ععاموسوسر 651 
عاغا صلتنته [أمعما؟ 2 
+( "كم | 11" !ا مملاناك "العلعة ,تغصائءحكمم عجعامووضر 53 
عا[ | حابتا علق م 

ب تلاط العلعم تانتا_ | نأعارصختطر تع | دمع [وانائعت ععامجوسر 55 
علاط أمعملا؟ ك6 
عطتاسكعل"ا للعلعق :عابط ملعم خعدع ندا ععامجوضر 5 
حزصاتاك العاعق :عابط “عق خدع ندا ععامسونر 58 
عصنتاسشتعل"ا “لماعم :عابط “لمعف خدع مدا ععامسوسر 5 
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بتانلا_ | ناعا, انارت عوقددع “امع [واناتمعدك ععجاموجنر 0 

إعاباط الله ١‏ -, افع [ اعد _أطابتب 71 
أأللاع. ‏ تم 

اعم 73 

تراعوع عا1 | نخمعص تأودمك كم 

5 


لاانالالانا: تداك عصرظ رمحا فمعوممق قم 
حت دك 11 07 


ععقمك تاعدة: ل" ل حركماعنا ١١!‏ كز | ارمصطناك لماعم جمع دوا ععامسدنر 78 
3 -ح- :نقداال أأعوات. 7 

ععمعر عدتاشئعل"ا لمعقفرصصانك لالعاعم ممع ندا ععاموجص 30 

مم دح :#ولاماك [زعوات. 31 

عممووع ١‏ ("اعوع ١١!‏ كز | ارمصمناك لماعم جمع ندا ععامسسنر 3 
عع 53 

كك ,ل" عمة 110 [ ا محزلوناك العلاعة ,تغصدتحوه ععاموسجن 34 
1الالاة. 855 

51 

,تاللا ا ناأعارواناطعع | دمع [وانااعى ععاموسجنر 3 

تلاط أمععاى تعاابانا المج 3558 

تناك “العلعق عابط العف ادع :دا ععاموجن 39 

بتانلا_ [ ناعا, واناطرئ عودددع “ممع [واناتمعد ععجاوجنر 3 

اعباط املق ١‏ -, افع [ اعد _ اباب 31 
آعم 9 

تلدع :ددا“ تمعموممق 3ت 

94 


ااانا بعكاء عورط نع |أداععمدمعدمرمق 5 
1ع _كما دح صاب 11 3 


1ع 11 امات لاأءاعم جم نذا ععامسنر 7ج 
مع _خالا دح نما [أاموات. 98 
(اتع !١ك‏ ] ا تعماك لماعم ممع نوا ععامسنن 939 
3]_خعالا دح نما [إامواع. 1101 
("اتع !1 ا ومكات لاءاعم جم نذا ععامسدنر 101 
دع_عانا ددح نما [زاموات. 12 
و" تع ا يا مات ااءاعم ممع نذا ععامسصنر 103 
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كع_كار؟ دح نميا [زاموات. 104 





( اك !1 ع ] ار تعماد لماعم جمع نوا ععامسوضر 105 
ضع_كارا دح نم كاد [زاعوات. لا1 

( "ادع !1 | تماد لماعم نمع ذا ععامجصنر 107 
#رع_كمار؟ عع نمام [زاموات. 105 

(امع !]| | ا تعماك للعاعم نمع ذا ععامسصنر 10 
8ع _مار ددح نمام [إمواع. 11 

(* 2ع !]ار كمعاد لمعم جمع ندا ععاوسنر 111 
بع_مارا دح معا [إموات. 11 

(" الع !1 | نماك لماعم نمع ذا ععامسجصر 11 
لل1ا2_كار دح نما [زاعوات. 114 

("الللع !11 ] اتع كاد لماعم جمع نوا ععامسوضر 115 
1 كارا دح نمم [زاعوات. 11 

(211! 811 ] عاد لماعم مع نوا ععامسونر 117 
12_كارا دح لمعا [زإعوات. 118 

(" 1غ !"1 ]ا تمعاد العاعم همع ندا ععامسصىر 113 
لات 1 

كعتااعم_كار دح جما [زعوات. 121 

(" لامع !"110 ا تعكاد لاعاعم منمعنذدا ععاووضا 1 
لمك _كامر؟ دح نمام [زعوات. 1-0 

(]أطاد 1١!‏ ] ا تعماك لماعم نمع ذا ععامينا 124 
ان[ لكانت_كار؟ دح مما [زعوات. 125 

( ا ١‏ | نماك لماعم نمع ذا ععامجصر 1 
لالكإعامز_مار ددح نمع [زاعوات. 12 

("ا 1 ات !"١1خ"‏ ]ا تمكاد لماعم خمع ندا ععاموسونر 1 
عدراشع_كارا دع نمم [إعواع. 129 

("اعدبادط !11 2 | ار تعمماك لماعم جمع نذا ععامسوصر 1310 
#لاشع_كارا ع ح نمك [إموات. 1131 

("لحطتاط ل" 11 ا مات لأعاعم ممع نما ععاموصنر 132 
غخ[]_كار ددح نمام [إعواع. 1 

(" انات !"10 ] تعفاد لماعم مع نوا ععاموسونر 134 
دغزرا_كمارة دح منممام [إعواع. 1-6 

(ل طلا ١‏ | ارتمماك لماعم نمع نذا ععامسصر 13 
[ععا)_ثار ددح نمام [زعوات. 1137 

( ات !)1 ]| ا رنعماد لماعم نمع ندا ععاموضر 1138 
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[لات[ة_مار؟ دح ماد [أموات. 139 


و(" اخحاواه !"11 ] تعفاد لماعم مع نوا ععامسوننر لاك 1 
كالابانانا_كا؟ دح نمع [زإموات. 141 

(" ل حتتخمنا !" ]تعفاد لماعم نمع نوا ععامسمرا 142 
عإساند_عار دح نمام [إاعمواع. 14 

("أعصوصص ا 11 ] ارماك لماعم جمع نوا ععامسصر 14 
بالأاع_كار؟ ددح نما [إعواع. 145 

(" ل صصع 1١!‏ | ار كمماك لماعم خمع ذا ععامسصنر تك 1 
عجزمم_مار دح نمع [إاموات. 117 

"لصنلا وما" 10> ارؤمعاك «اأعاعم جمع اها ععامسصر 118 
الاعلذظ_كار دح نما [إاعواع. 149 

( ع تنتندنا وما" 1١‏ ]اوماد «اأعلعم نمع ها ععاوجنر 1510 
انكل" _كار؟ ددح عنما [زاعوات. 151 

( "كد !11 | اتعماك لماعم خمع ذا ععامسسنر 15 
عا عاعغنا_كار دح عنما [إعموات. 1 

(" لاعن" 11ب ار وممات «أعاعم نمع نذا ععامجور 154 
1-55 

لاناشص طالخ _كار؟ دح نما [إاعوات. 15 

(" ناض 11 | ار تع ناك لماعم جمع نوا ععامسجضر 157 
شط لالم _كار؟ عدح جمماة [زاعوات. 158 

( 1 تلاط ١)‏ ع | ا تعماك لماعم خمع ذا ععامسسنر 159 
وناشص الما _غار؟ دح نمام [زعواع. نا1 

("اتصصياص!" 11 تعفاد «العاعفمنصع نهدا ععاوسصر 11 
تناشط ل«ارالم_كار؟ دح نمع [اعواع. 152 

( لاض 1 | ارماك لماعم خمع نذا ععامجصنر 15 
بخص سرالمخز_كار ددح جما [إاعوات. 154 

(" كاناض ا 1 ع | ار كتمكماد لماعم جمع نوا ععامسصر 155 
كناشصمارالاز_كامة دع نمماد [إاعواع. 15 

( ل كاطلاض ا 1 | ار كماد لماعم خمع نذا ععامسصنر 15 
تاناشص الما _كار؟ دح جما [زاموات. 158 

("لخخصطناض!" 11 تعفاد «اعاعم منحعنذدا ععاوسصر 15 
“ناشص مالم _غار؟ دح نمام [زامواع. 17 

( ”الاك 11 ] ارتع ناك لماعم جمع نوا ععامجضر 1 
شط الم _كار؟ عدح جم ماد [زاعوات. 172 

( لاض ١١‏ ع | ا تعكماك لماعم خمع ذا ععامسجسنر 173 
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بخص طالخ _كار؟ عع جما [زاموات. 174 





("الصصياضة "11 تعفاد لاعاعف جمع ندا ععاوسصسر 175 
16 

اناك[ ا الاممظ_كار؟ دح عنمي [إموات. 1 

(" ااكك ا" 11 [ ا جتمكاك «أعاعم جمع ندا ععا مسن 178 
ناناش_خارا ح-ح عنما [إاعواع. 17 

(" لصم ١!‏ كز ] ار كماد العاعم نمع نوا ععامسجسر 110 

نا شممصعه5ك_كار دح عنم [إاموات. 1131 

(" امعد 1١!‏ ع ] ار كماد الاعف جمع ندا ععاوسن 12 
شط زلاك_كارا دح عنما [إاعواع. 1533 

(" ا طاباك ١)!‏ كز ] كماد العاعم نمع نوا ععاموسنر 154 
عانا1[”أآنا_غارا ددح عنما [إاموات. 1535 

( مانا 110 ع ] ار كمكاك لماعم ممع ندا ععاموجن 136 

137 

اش [[صئفب_كار؟ ددح عنم [إمواع. 1535 

("لجاعها عصدع!" 110 ا لفاك لماعم نمع نوا ععاوسننر 139 
ا لمارالا _كار؟ دح جما [زموات. 1510 

("نتاعدا تصناض !11 | اجتمكات لأعاعم جحع ندا ععامسصر 151 
الانتظطاك خا دح عنما [إمواع. 12 

("طتاعدا أده ا" 11 ]ا تماد لاأعاعف نمع ندا ععاوسسنر 33ظ1 
94م 

مدع 155 

ازا الالكل؟ | ؟ز] اكع اك لماعم نمع ندا ععامجنر 1 

االالاع. 137 
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لتعكاك العامة ,ل'حمة ١١‏ !ا رحرزتصناك العامة ,تعتصائءحوئت ععامسن 19 

ب تلاط املعم تانتا_ | ناعاركاتناطلتاع | دمع [وانائعت ععاموسنر لانات 
علاط [أمعجلع؟ 21 

حزحرناك “لماعم عابط املعم ادع ندا ععامجن 22 

,تاللا | ناعا, وا ناتارئعومددع “امع [واناتمعدك ععجاموجنر 23 

اع اباط املق ١‏ -, تع | عط _ طبترا 20 
اع لات 

مراعدع جنعكااد تعمد معموممق قلات 

513:1 اعقوتم “لات 
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شفرة المشروع !١1001.8517[‏ 1//106] لا نقوم فيها بفعل أية أشياء جديدة عن 
ما تعلمته حتي الآن .. فقط لتقسيم الشفرة نقول أن هناك لزرين .. الأول 
يقوم بتثبيت خطاف موسع .. والثاني لإزالة هذا الخطاف .. ويوجد 3 إجراءات : 


الأول 170016/1116/ال50301 يقوم باتيان اسم عنوان النافذة عن طريق مقبضها. 
الثاني 06©00131م8 يقوم بإاضافة حرف الأسكي إلي صندوق النص. 
التالث لإع00566©13|1ع06مم8 يقوم بإضافة بعض الوظائف الخاصة إلي صندوقف 


النص .. وهذا الإجراء ليس نهائي ويحتاج إلي بعض التعديلات والإضافات مع 
الإجراء الثاني والأول .. ويمكنك أخذ هذه التعديلات علي عاتقك. 


61ظ1 


لحقن الديناميكي 
>- 1100121115 121ىر 


سنقوم في هذا الجزء بتوضيح كيفية اعتراض دالةء 1طم داخل تطبيق ما .. 
وتغيير عنوان تنفيذ تلك الدالة إلي عنوان إجراء بديل لدينا .. هذه الطريقة 
يطلق عليها 00كا100 1طق .. 


وتوجحد أكثر من طريقة لتحقيق هذا الأمر .. وسنتعلم طريقة التغيير في جدول 
عناوين الدوال المستوردة ©1361 2001655 1112016 .. وسنطلق علي هذه 
الطريقة ١100110‏ 1281 .. فإذا كنت تتذكر لم نقم باستعراض ال 1681 07 باب 
شرح صيغة الملف التنفيذي 25 .. وسنعود لإستكمال شرح هذا الجزء هنا 

فقط بعدما نتناول كافة الدواك الحكرة التي سنتستخدمها في المشروع. 


© داله غ51101م10325113ع10011ع21ع:2) : 
تقوم هذه الدالة بأخذ لقطة من التطبيقات والأكوام والموديولز والثريدز. 


1 أه أمتاعمهقنه 3 ععلق] تملأعننط؟ أمطعمهمك5 متماعطاامه اعامهع ني ع1 
5 عللة ,قع1نان0 ه27 ,قمقعا علطا 35 أاعنا 5ق ,معععععمزم لمع أاععموة 
.قععقععمام مدع بلط مع 5لا 


اأمطاكمة ومكتماعلاامه اعاهع ا ااام 
بعوت ناك لالانلالان] 
ممع م132 لالالالان] 

/ 


المعامل الأول 305اع/ثال : 
يحدد ما الذي تريد تضمينه في هذه اللقطة .. والقيم التالية هي التي تهمنا 
في الموضوع الحالي : 


2 - 55ع1482200ااد_11320.5 





تضمين كافة الموديولز للتطبيق المحدد | 8 - 8الا71325_51/860100 


المعامل التاني 15325210655110 : 


يحدد معرف التطبيق المتضمن في اللقطة .. إذا كانت قيمته صفر مع 
استخدام الراية 5818800800655 .. فسيتم أخذ لقطة لجميع التطبيقات 
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الموجودة علي النظام حاليا .. بينما إذا كان قيمته صفر مع استخدام الراية 
تالا58/851100 .. فسيتم أخذ لقطة بجميع الموديولز للتطبيق الحالي 
وبالتالي إذا اردنا اخذ لقطة لموديولز تطبيق محدد نقوم بوضع معرف التطبيق 
في هذا المعامل. 


بعد تجاع الذالة :ستعوذ.نقيفقة لفقيض اللقطة. تستطية اس تكرام هذا 
المقبض لإتيان التطبيقات والموديولز عن طريق الدوال التالية : 


115 55321ع000 
<ا55321[6ع00م0 
وكلا الدالتان تستخدمان بنية هي 2 |اع 20055 لتخزين بيانات 
التطبيق بها. 
لسرد الموديولز : 
00101325 
»106 32ع00101/ا 
وكلا الدالتان تستخدمان بنية هي 2 | لاع الارما 110 لتخزين بيانات 
الموديول بها. 


سنستعرض أولا طريقة سرد التطبيقات : 


© الداله 1:56 5532!1ع©2:0 : 
تعيد بيانات أول تطبيق المصادف في اللقطةغ0ا5وم503. 
1151 1118 أناصطاة 111311011ه آلا ععنلع اماع أهر[ز ا لتععععورن لرمتعصرط عا 
51101 م513 51811/ز5 3 ذا عع ][الامموع وعمععمرم 


لغىر ا لتععععورة اناق 
بأمطعمةدذكاط عا اناللاما 
عمما 32 | لأعاذذ ع )نايدنس | 


1 


المعامل الأول 550305806 : هو مقبض اللقطة المعاد من جراء استخدام 
الدالة أ50م32503ماع001 1 عأنع). 


المعامل الثاني ©مم! : هو مؤشر إلي بنية 6800855018732 تستقبل 
بيانات التطبيق. 
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وتعود الدالة بقيمة علا!! إذا نجحت وإلا ستعود بالقيمة 53156 . 


حاكهم 


كل 


الداله غ21 2206553 : 


تعود الدالة ببيانات التطبيق التالي في اللقطقأها5م503. 


81 18 الاصطة 111 3 171ص أترا عمعنتمواععم أجرم لطر ععوعمومن] روراع ارط عا 


01 ص53 تل8 51 /ز5 3 ثرا مع ممعم ومعمععمرم 


عاك تععععون _اناناق 
بأمطعمودرك5 عا اناللاقن] 
عمما 732 | اللأعاذذ انامس | 


1: 


ومعاملات الدالة هي نفس معاملات دالة]5532]5ع2]00 .. 


© البنيه 1!1139/32 21008551 : 


تحمل بيانات التطبيق داخل قائمة التطبيقات في اللقطة .. عناصرها كالتالي: 


مذلط | للأعاذكط لاط مناه 


ع2 الال نالا نالانا 
6ك اررى ااانا 
لااوعععم 1328 ااانا 
لااصقع1 !]الات أ8 320لا انان ] 
نااعانك ما 32لا انان ] 
5م18 | اكت اناا ] 
لا امقععم اومرح 320 ااانا 
8 انا ممعم عااراقة 
25 ااه لاا نالانا 
اشر غعنكفرار! | عاناع:؟« حامة | 
26 قا ره راع |32 ااانا 
لحك عع ع عا اسك ااانا 

32 !ا لأعاذذ نط ر 


وفيما يلي توضيح لبعض عناصر تلك البنية : 


«ه 01/512 : حجم البنية بالبايت .. وقبل استدعاء دالة ]01005532115 يجب 


تحديد حجم البنية بالوظيفة [1/781/32 5806255 606 2ز5]. 
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٠ه‏ (اإ551ع32200] : معرق التطبيق. 


ه عاأعع»ع52 : اسم الملف التنفيذي للتطبيق .. ولإتيان المسار كاملا للملف 


التنفيذي نقوم بإستدعاء 11001016321154 لهذا التطبيق .. ونفحص العنصر 
طاةمع<522 من البنية 20/781/32_انا100/!. 


والآن نستعرض كيفية سرد الموديولز : 
© الدالة غ5:: 110010132 : 
تعيد بيانات أول موديول داخل تطبيق. 


غ5 عل األادداد 1اهدتأمتتتماما عععتع اعم أخهم] اندع انالسالاا ماعنا عدا 
.6855م 3 لكالا لعأدءوؤوهد عانالمكلم 


) امأ انمدع ادنماا انون 
بأمطاعمودرك5 ا انالكامل 
م 732 الأاعاعا _الانا لاض | 

/ 


المعامل الأول غ+550م5563 : يحدد مقبض اللقطة المعاد من جراء استخدام 
الدالة أ510م32503ماع|00 1 عأنع). 


المعامل التاني ©(2! : هو مؤشر إلي بنية 11732لا6ع الا0ا110 تستقبل 
بيانات الموديوك. 


وتعود الدالة بقيمة علا؟! إذا نجحت وإلا ستعود بالقيمة3156آ. 
© الداله غ<7عل21 1100113 : 


تعيد بيانات الموديول التالي داخل التطبيق .. وللدالة نفس معاملات الدالة 
110010013211151 وتعود بالقيمة علا!! إذا نجحت وإلا ستعود بالقيمة 5315©6. 
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تعنم عل اأتاهمنات اه تأمتتكنه اما عععتم اعم أجعرعلا اردع اباله ]| تمنعررط عط 
.830لا نه كوععمام 3 كلأأناا لعذأدءهو5ود عانالمتم 


) مدعلا امتعادالواا _انانق 
بأمطعمودركم عا انالكاما! 
عمم! 8732 الااعاعا الانانلةه | 


1: 


© البنية 6210171032 انا 1100 : 
تحمل بيانات الموديول داخل قائمة الموديولز للتطبيق في اللقطة .. عناصرها 


كالتالي : 

! 32 الااعاط _الانانالا تصصاة 

ال ااانا 

نأا ع ه13 اناا ] 

لاامسعععمم 132 اناا ] 

م تعاطاتا لش ننه 

3 6 ل رع ع سرس ااانا 

]م امشع ع جح ممم الاق 

مراع 835 انر راان 

عاناكه اانا الا نا انا 

اشم_غعنفرار! إعاوه اناده تلان 1 

اشضط_عنمار!] |رلتج نامع« حامة 16| 

25 انان ايان اانا 
2732 الاااع الاناناا ‏ 


«ه 01/512 : حجم البنية بالبايت .. وقبل استدعاء دالة 51100101321156 يجب 
تحديد حجم البنية بالوظيفة [111732 لااعع الانا ١/10‏ 51201]. 


٠ه‏ (1آ011ا10321100] : معرف الموديوك. 

ه 7008358006 : عنوان بداية الموديولك داخل التطبيق. 

٠ه‏ ©لا61100 : مقبض الموديوك. 

»ه ©لا52/100 : اسم الموديوك. 

«ه أا23ع<*522 : مسار الملف التنفيذي المحتوي علي الموديوك 
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© الداله خعع120ج بالا : 


تقوم هذه الدالة بتغيير حماية الوصول إلي منطقة في ذاكرة التطبيق الذي 
قام بإستدعائها. 


تلت تالنااععأصزم ككمعععة عطا كعقضقطع تملأعضلطة تععتوئس '" لهسارالا عدا 
عط أه ععهمرة 55ع300 أوناترك: عط ضا كع لقم لمع ]ا متتتضمع أه لصامعم ع 
بلاعاك عانر "ا اقناترايا ضما عع ]انك تمالاعصل؟ علط | .مدععع مم ودالاوت 
855 دامر 'أثلة أل لاملاصعآاصام عممعدععة عطا معوصقطء ماطس 


تعاس 'الحسارانا اناناق8 

يقم جنات كما لاانايا8 | 

بعد اكاك لاخا ذا اانا 

حك حبات /111 اغا نا لايان] 
تك ندم الصا اانا لارام 
/ 


معاملات الدالة كالتالي : 


1 - 55ع8001م! : مؤشر لعنوان بداية المنطقة المراد تغيير حماية الوصول إليها. 
2 - 0512ل : حجم المنطقة بالبايت المراد تغيير حماية الوصول إليها. 


3 - عم ط/لاع 61 : تحديد نوع الحماية الجديدة .. ومن الممكن اختيار أي من 
القيم التالية والتي سبق توضحيها : 

/ا الاممطمعه_ع هلمم 

ع17/لاممعم_عملمم 

ع7نامعلاع_عملمم 

مدعم_ع [1نمعلاع_عملمم 

171ل لاممعجه_ع 1 نامعلاع_عملمم 


4 - 1060105016 : مؤشر لمتغير سيحمل قيمة الحماية القديمة لتلك 
0 


عند نجاح الدالة تعود بقيمة غير الصفر وإلا ستعود بصفر. 
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جدول العناوين المستوردهة 
ع1 !ا د5دع:8001 1ممدرا 





لمقرفة فاهة ال ته[ ؟ فمفطظمر الذؤاك التي تقوم باسهكامها :قن :ذواك 
مسد ورذة :من ملغات انا . كل ما تعلقة عرف 8 الذواك هو اشهاتها: واسمر 
مكتبة ال اا الموجودة بها. 


رفوه المدر حمر نوضفوا فم الملق» السموتعنن :نوها نعمر تفن الملت 
التنفيذي .. يقوم ال 03066 2 بعمل جدول لتلك الدوال بعناوينها علي 
النظام الحالي مع ترتيبها (00103 لا8 .. لكي يستطيع البرنامج الوصول 
لعناقين بلك الذواك د تهواء تفن ظرنة: الاشيور او عن ظرى: الترشيت: 


هذ الحدول هوال. ‏ تقل ب.وتهدل الك هد | الحدول:ؤاكل :ذاكزة: العلف 
التنفيذي .. فإذا كنت تتذكر بنية الملف التنفيذي كانت كالتالي : 


علا 5 532 اعلطقطلا_آللا_ع 111806 
2 00 ع1 لا 5103 


<> لاع رامع ل_ غ211 _غ نملا مع30ع اع 
<> 32لاعرامع1_ املا10 1 0_ع م1 00101 
درالاع 532 ا!ع]طقع1_١للا_ع‏ 111806 


حيث أخر عنصر يشير للبنية 488601532!ا_111462_07217101/81 والتي تحتوي 
على : 





1 لاا 5 ١15812132‏ _ اذل 1١‏ 111868_02110 
2 (اثا0/لارا 1111306835 


(<>)ملال 16 101537 )18_12 04ا_ع0م 1 003001101 
ددالااع 12132 11_16 110 1116_0252 


حيث أخر عنصر هو مصفوفة من البنية /2_0/878_01221011 11186 : 


1ل 5 10147 221156--111866_206185 
532 (2اآا0/ل/ار| ١/05‏ 





37 راآناك/الار|ا ©5172 
درالااع 101437 101145--185 1188_1086 
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تحتوي البنية السابقة علي عنصري العنوان الأفتراضي والحجم لكل بنية 
بيانات عالاأ©لا1أ5 10313 .. 
ويوجد 16 عنصر من البنية :1810158501019 048ا_1118480 نعرفهم كالتالي : 


الالصاعع اط مم8 0 لل | 0 ا 
الاامععناظ وصسة لل | 1 ا 
7 
15 


العنصر رقم 12 هو بنية بها عنوان جدول العناوين المستوردة .. ولكن عبارة 
عن قائمة بها عناوين الدوال المستوردة من جميع المكتبات .. بينما العنصر 
رقم 1 هو بنية بها عناوين الدوال المستوردة مرتبة تبعا للمكتبة. 





وبالتالي سنعتمد علي بنية بيانات العنصر التاني [لااماعع]أما 0م12 ] 
وبداية هذا العنصر عند الإزاحة [801] من بداية توقيع الملف التنفيذي [غه2] 
أو يتم الحساب من عنوان العنصر [8+/035801:6]010] .. والقيمة 8 تحدد 
طول اول عنصر [لإ16©101(ا 2“001] لنصل إلي العنصر التاني .. ومن تم 
نحصل علي عنوان بداية قسم الاستيراد. 


وقسم الاستيراد [5©6©600 1722016] عبارة عن مصفوفة من البنية 
10 111401201 .. عدد حدود المصفوفة يتحدد بعدد ملفات 
الاا0 المستوردة, حيث لكل ملف اا بنية 1115087_0850512101_ع 6م11 


فمثلا إذا كان لدينا ملف تنفيذي يستورد 4 موديول .. فمعني ذلك أن دليل 
الاستيراد سيكون به 5 بنيات 111801_1115051_0850812101 .. حيث 
البنية الاخيرة تكون صفرية كمؤشر لانتهاء دليل الاستيراد. 
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عناصر البنية 11120151_1055)15121015_ع 111800 كالتالي : 





[ناللخااط انا | د1كظ_اطعنا_ |[ لاراناام]_حاوات “1 
أاالا 
لك دعأو عاد دا 
لعل تاحباط ا غى تر اقصاواءت 


لزع 
+ لال دزممة اطع أتناعلر 1 
لك قدا ملعت تمع 
لال 311ل" 
للك لاط [ أجمع 


كنالاع انا | [خا_اططنا_ ا لأنان“ا]_ادات "| 


حجم البنية 20 بايت .. ونلاحظ أن التوحيه 0011101 يشير لجمع العناصر 
المتضمنة به تحت عنصر واحد .. بمعني ان كلا من >األثالاط !]5 |1 0109103 و 
5 يتشاركو نفس الإزاحة. 


: )أ 1انا١11 ]11:5 |أت021011‎ ٠ 
عنوان نسبي يشير لمصفوفة بنية )انالا _ع111406 والتي‎ 
سيلي استعراضها .. وبعض مترجمات الملفات التنفيذية تضع قيمة هذا‎ 
العنصر بصفر .. ولكنه متل العنصر الأخير »!١1لا 11511 يشير إلي مصفوفة‎ 
من البنية /041آ_>ال الال _ع1!»/486.‎ 


ع 6531112 "01101113119١‏ ليس لهما استخدام هنا 
هء 13161 : عنوان نسبي يشير إلي اسم ملف الأانا. 
٠‏ ©ل1انا1:5]1© : 


عنوان نسبي يشير لمصفوفة بنية 6878 )!/١لالا1ت_‏ 111662 .. عدد حدود هذه 


المصفوفة يتعين بعدد الدوال المستوردة .. أي (بنية لكل دالة ) وتحمل هذه 
البنية معلومات الدالة كما هو موضح كالتالي : 
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حدملاث اتنا لارام |_عاحات "ا لالاعا ك ا كنا_“الةا لان |_عاداث 1١"‏ 


[نالاكااط عدث ا كنا_ةالةا ران |_ادات ١‏ 


1ب 1011لالا 
للك وصتطكط عع رح ستردع 
7 لك دل عصبيع 
7 لك أتدنأك نا 
ع 3غ3ناآناددح لات 
لزع 


كنالاط دتت | شكنا_“الةالالن |_عاحاث 1١|‏ 


من التعريف السابق نجد أن كل 26178 )الالالا1_ ]111866 عبارة عن قيمة 
0/0110 موحدة .. وعند بداية تحميل الملف التنفيذي من قبل ال /0306] غم 
فستكون البنية متمثلة في العنصر الأخير [60016550193]68] .. والذي يحتوي 
علي عنوان نسبي لبنية اخري هي [غ41/12لا_لا1114800_1112011_8] تتكون 

من الأتي : 

انالاخا !5 عاك لذا_ كع_ | نأنادك"“"]]_عاحات "1 

بالل | 

لال 1ل" 
طنالاع عامائل_ كط | لأرانك“]]_عاحات “1 


٠ه‏ 2811985 : قيمة 010 بحجم 2 بايت تحتوي علي موضع الدالة “1506 في 
جدول العناوين المصدرة ©1301 8001655 001“ داخل ملف ال اانا ويتم 
استخدامه من قبل ال :0306| 8 أولا للوصول إلي الدالة .. حيث سيكون 
الوصول اسرع عن طريق موضعها .. وعندما يصل للدالة يتم عمل مقارنة 
بالأاسم .. وإذا لم تكن الدالة المطلوبة يتم عمل بحت عن الدالة عن 
طريق الاسم. 


ه٠ء‏ 1132161 : يحتوي علي اسم الدالة المستوردة منتهي باالالا. 


بعد أن يقوم ال :0306| 55 بالبحث عن الدالة والوصول إلي عنوانها في جدول 
العناوين المصدرة. 1م في .ملف الك. الا .. سيقوم باشتيدال الفعتضر 
[500:6550031] الذي يشير للبنية [2/اذلا_/ا11150817_8_ع11186] بعنوان 
تلك الدالة .. ومن ثم ينتقل لإيجاد عنوان الدالة التالية. 


والآن لدينا عنصرين وهما لاط 3|561مأو01 و عاناناط !]115 .. كلا منهما 
يشير لمصفوفة مستقلة للبنية 01|0878ا0ا71_ 111862 .. وقبل أن يقوم ال 
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0301| غظ بعمله .. يكون كلا العنصريين نسخة من بعضهما .. لا فرق سوي 
أنقها مضفوقين «مسنتفلتية. 


وبعد أن يقوم ال 030/7 !| ع6 بعمله .. فالعنصر الأول )لاط غ5 |0110 يظل 
مؤشر إلي جدول لاسماء الدوال .. بينما العنصر الثاني >| 11لا( 1 ]15 يتغير 
ليصبح مؤشر إلي جدول لعناوين الدواك. 


وفي حال إذا أراد الملف التنفيذي معرفة أي عنوان تابع لدالة .. فيمكنه ذلك 
عن طريق العودة للعنصر الأول)!(اناط 0110103121581 الذي لم يتم المساس به 


وبالنسبة للدوال المستوردة عن طريق الترتيب 0101031 /إ8 .. فلن يكون لها 
مؤشر للبنية [5آ810|١_لا11186_1112087_8]‏ .. فقط سيحتوي العنصر 
[2674الانالا1"_ع11186] علي ترتيب الدالة.. 


وفي هذه الحالة يتم التمييز بين إذا أحتوي [2878_)/الال111802_11] علي 
[55060313ع800] أو علي [0101031] عن طريق البت الأخير .. إذا كانت 
قيمته واحد فإن ال 31 بت الباقية تحتوي علي [|2010153] واذا كان قيمته بصفر 
فإن ال31 بت الباقية تحتوي علي [2001655011038]. 


إلىي هنا انتهينا من جزء ال1295 ويجب عليك قراثته 
مرتين علي الأقل لفك أي التباس موجود به. 


وتنيتة ل الآث لكتارة متشووعرقوفربالتفنير قي 'عنوات والة: [طقر واخل زوك 
العناويق الستورذة لقا واستدذالفا يعنوات لإحراء لدننا, 


سنقوم أولا بكتابة مشروع ال 5“ الذي سيقوم بحقن مكتبة ال اا0 داخل 
البرنامج الذي نريده .. ومن ثم ننتقل لكتابة مشروع ال لاما والذي سيقوم 
باعتراض دالة ال851 داخل هذا البرنامج. 


مشروع ال تلا سيكون باسم [851 1001ا] ويحتوي علي زرين أحدهما 


يستخدم لإلحاق ملف ال اانا لدينا في برنامج وليكن ١0]3030‏ .. والثاني 
يستخدم لفصل ملف ال اانا من برنامج النوتباد. 
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شكل المشروع سيكون كالتالي : 
دعاك 


اانا طعداع م لان طعهلاث 


ناش اانا 1028110 لأناش| اث 1001:8111 





شفرة الملف [8581.1056 100[2!] كالتالي : 


الل كمتتداع ابت ععبااعر1 1 
عطاك 3تأعدرععا علباعصز 2 
عدا 2ت عدبا عباعص1 3 
عضا 32 أعصوصا عمتبناعمدت ك 
الاتة. قط اقل اكد دقصست 3ت مركعخصط ةنا ععبناعص ‏ 5 
ةٌّ 
طلا 2تأعصعععا طاتاعلساعص "” 
طلا 2تنعكبا طاتأعفبداعمدت تخ 
طازا تا عصوص ا طاتاعلباعمرت ه 
لا 
ات تان الات تع بان [ 1لا نالكناك: لاآللظط عصءطوانا 11 
12 
01151. 13 
1ل الت 1إتانااكإنا_نالالاً 14 
1لالا1 لاومعت لأات]| [ش_لكاا8 15 
2لالا1 لاومع لاأات اعنا_لاا8 15 
لل لي لاد الول ليل لله للد الل ل للد ال ال للقي للد ال ل لبقو ال ال للق يلد ال ل للد ال لي ل لل لو يي لل ل ل ل 0 17 
دغأقل. 13 
(ذلا) تربك كدح داك علاط 193 
ا ليل ليل لباه الول ليل لله للد الل ل لله ال ال لله لل ال ل لبقو ال ال للق يلد ال ليل لله ال ليق ليل للد الو ليق لل ل لو 6 ل لوو مر الات 
*3غآأقل. 21 
00 ععددغأ5صاط 2 22 
00 اإعصعةاط ‏ 23 
0 ععخطناتقصا 24 
ل “عشطناصصط 235 
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لل ددع د ندا 
للك 51جتح ددم 
# 20 «ععفع ادام 


ع نت كل | لا اطداع_ا انام ل ان] 
حم حت خط | لإلاعع ااام فرعره سان 
010 متكا 
00 اصالاك 
7 00 تاك 


عل كاحدعمن | ندل" 
ل ل ل 0 


شفرة الملف [851.8511 )10016!] كالتالي : 


كات., 
اعقهم معصدوعم علط 2ت اأدعلاه ,خأهاأًةا اأعلودن. 
مما أكدمعه عدت 110138 تزقذالء 35 ١املانرن‏ 


دصل آناخم عاصدن علإعبلاعضر! 
0م . 


:5111 
ا الالكارعااعصدتاعاراعدمااعى ععاموسسنر 
87# عاداة كم [طا متملم 
5أد كنت حلصم تلض[ ععاوجسر 
,ا الالكا, 1تاناافآنا_ناناآرعدحة حصاطرممةءوطنزمطودادانا ععاوجن 
ا الالكايعمءصوانا علوت 
لاروكععم رط ذأيرع عجاوبن] 


ا ا ا ل ل ل لي ل ل لي ل ل لي ل ل ليل ل ل ليل ل ل لل ل لل للق ل لل للق ل ل إل ل ل ل ل ل ل 


لالت تعبا : ورت رت ناشنم 1 ل[ لا: قدا اياج نال" نتاح: مبثانا عونام عدرناوانا] 
كنات نم : ددم 
لدا"ألار مقع مولن 
تاناات]انا 1 111_امابتاح دجزهع 11 





أت 
ات 
ات 
لت 
لات 
5 
3 
3 
4 
3 


بم زع 


لذ كلرىر صا 


بمو مهمو مم 
5 ند تت تا اح مر زح 


مم مم 
ذنا كلم 


15 


بم 
1-1 


17 
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نالكاك ل" مانت)_امأإبتتح دبعومع [زموات. 24 


زحمةخطت نام لوعي دع بعسولم 2 
أدلورووءدنابف تام نوميس باع بمعسووم ظ 
ماع10 م_لكام- د ليع 11 37 

لات ا اه_ل]] 8ح ديرهم 11 2 
طاعدتكاث لأاى ا 

دلاخ اعنا_لا امد دبجهع [زامواع. 30 
حاعداعنا أاىه 531 

1الالاة. 5 

1الالاة. 5 

عأكنا ان _امأبفاح دبومع [زموات. 34 

لأ كلأ وحار ودات انا تصع ععجامسن 35 

ع5 35 

عذاث ,ندع مورن 3 

امم 33 

1الالاة. 33 

علا ا ,تدع متورنر الك 

اعم 41 


مراعدع عددوانا تنك 

ل ل ل لب ل لبد الو لي ل ل لب ل باد الو ل لد ل لب ال ليلد لو ل لد ليل للد لي ليلد ل لي ل لي للد ل ل ل 77 ل 72 0( 4 تك 
اطع نارا_أاض 1‏ كك 

(" ات د اعحتتعها )1 | ار عا تمد داع اعد ماعن عجاوين]1 ك4 

تمع أعمءحكانا متودم دك 

كِ 

("خبناة احالالتصض ا ١١خ‏ | ا راعصضصةاطر ددع عشعمطاعي) ععاوسن]1 4 
عر فطخ تدا ملم 4 

لاك 

( "ات احاناصعط 1 | ا أاعص عاط ددع مضعم داعي عجاوبن[1 51 
تمع اععشفحا| _اععع نودم 52 

5 

عباط ملعت لا اقط_عزت اما ب تصاعع إناغخدع لماعت عجاموبجنر 54 
(["1. _ااناةاحصلا؟ 1١‏ ؟ز | ل عابط اعأعفخدع ندا ععامسجنر 55 

مك5 

عباط العاأعقرصع ندا ععاوجن]1 5 

تع مع لاك صمحم 58 
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اعم 539 

مدع طنا_أأم1 لام 

ليل بل لل ال ل للد للد الل ل الله ليل اليل لب الله اليل ليل لل للد اليل لي للد للد الو ل للد ال لي ل لل لو لي ليل للد ل 2 ل ل ل 000 1[ 
ام ناآك_اعب ‏ كدت 

تارك [دمعدومع نولم 683 

نار 2 غخصحاكمقصطءتماإعطامه [عادعء عيعاموسونر َم 

, لرددكطا توكلم 55 

نكم الإعوودع مط امععاى عمإك بال متعم نووم 3 

متعح لماعت مقضخط ىعد تومقعومع عياوينر 5 

لم]ط_أنردل"] 5 

عاعصبرعدى متعم لومز عينع, لاممعاصة" ١‏ | ؟ز | ار تممع ها ععامجصر م5 





- د يزوم 11 1 

لاآدودعدم ‏ م خط تغط عزمع نولم 71 

ع ل [دمععوزع نولم 1 

ددع ا نلمط_أاباع ]الال 23 

أأللاء. 7 

تعن لماعم درخصكط, أ جتعللاعتوجععومع عياوينر 75 
دديزوع 1ل 95 

ددع اد ةلماط_ باع تزاالال 7 

أأداء. 75 


ددع االط_أترزعل"ا ]انار 7 

نم_ ايارع لاك 

مقصكط ,رعاتصدلتاعددات) ععاموسجنر 31 

اعم 3 

ملعوع باوآط_عأقن ‏ 3خ 

ااا و ةل امم (نلم 
عمنام داعدطاامق كت 

عنا_أأاض][ اأأاىه 836 

ناآط_غعنا أاده 3 


ح ل [ووجعع دم 11 35 
اعم 39 
أالاة. 91 


اددع صا لار ددع _اناث_ااشض_دكدع_ا اط دوع عم تمعومتب ععجاوبنا]1 41 
ع مجع عط ناذا نولم م 
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111“ ماعطا دنع الات اال التاركوععص عط تع عداات اخبلطءث؟ ععامبن[1 33 
| 1الااباشعنا_اداتنم 34 

تمع دعت اك نمدم 35 

ع اباط اااعلعق عدت اكت ممععص طاطم تصممع “ادمع عم ميث عجاوبن]1 95 


اال الخال رصع الاك 3 
العاشحاا_الناتصارلاء ا الالكارئعععد اط تمعءحا | عاصمموع هعادع نف ععجاوبن][1 3 
ا الالكا,لا, تععثاك 3 


تت اعمععرا | بعل" جولم 11010 
لا <-! تمعرحا | شخعل" 11 101 


ب("نعناعتطات اانا" 11 1 ا ا الالكاى“«تمطعودددعام ععاوينا]1 102 
ا الالكارز 2ددنا )1 | ا 1 
فمععءط | منعل"ا «اعلعم عاتصدتاعدماد ععامبن] 104 

تتعالأعى «عاعكااك اللعاعم ممعصعمعططار :دع طادبطئر؟ معاون[ 105 
عطشع اعم_اماعام 1 

أأعوا. 10 

لارلارل"اععمااقع خحاعقطاات 11١‏ > 1 ام ا انالكاى زم طعوددددالم ععاوينا]1 10 
[اللاعء. 10 

اعم 111 


تدع طعوخاش 111 

ليل لاد ال ل للق لاد ال لب للق ملب ال لبق لله ل ال ل للد ل ال لل للد ال ليل لل ل الل لين لل لل ل لي للد ل ل 3 ل ل 11 
عملم تاعداعنا 113 

عانا_غاض[ أأده 114 

ناآط_غعتا ااه 115 

ح د ل [وومع 0 11 11 

اعم 11 

االلاة. 113 

ع[دعععصرط, حت أصحاكمقصطءتماعطاده اعادعن ععاموسونر 113 

6, لردداكلا لمكم نا1 

52م | لامح _الانانال"ا أمعجاجرعع كسك عناوم جمدم 121 

ناتلا لماعم ممصكط عو طدتعابعدل» ععامجوصر 122 

:عابااعدا"ا_ ادلم 123 

عاتم مامه عتنانال"ا اأعاعقز' اكت _ااناةاصدت 11 | ار أاصمع ذا ععامسجصر 1533 


ددجوع آل 1 
اداعتعوة لاعغصصم. تنا ناما نمع نمدم 12 
لتقع, اداعقعاباعدم] نمدم 12 
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عاعدال"ا_ ابزح ترحرز 12 

[اللاة. 129 

انالك" “العاعق مقصكط عأنتع ذا عابعدهم] ععامجوصر 1310 

ح ح بزوع 11 11 

عاعدا"ا_ ابزح نرحرز 132 

[اللاء. 1 

عااعدا"ا_ نيمل" برحرز 134 

:عابااعدا"_ ابرع 135 

محصكط ,عاتصد ل عددات عيعاموينر 136 

ادوع صنع لاب ددع _اات_ااش_كطدع_انناط ججععد دعوت عجاومبن] 137 
8 دجعع ص إنانا نولم 135 

التاعشفطا|_اعص ل نام اال الكارككععم طحا معط | عتصموع علعادعر) ععاوبجن]1 139 
اال الكارلا, دعق عااددا»] ذالك 1 

تمع دمعلا | نعل" ملم 14 

دكعع طنط ,عاعصدندعدداد) ععجاومبنر]1 142 

معط | تمل" بعاءصدنعدداد) ععاوبنا]1 14 


اعم 14 

لقع طعتماعنا 145 

يي لاد ليل ل الله اليل ليل لله للد ال لب للد مل ال للق ليله ال ل لله ال الي ل لله الو ليل لله للد الي لين لل ل ل لل للد ل 3 لق ل ل[ كاك 1 
513:1 عصضصم 147 


حيث تتكون الشفرة من أربع إجراءات .. هم كالتالي : 


1 - 1711_058 : وفيه يتم عمل بعض العمليات الابتداثية .. كاتيان عناوين 
دالتي /ه131طلاعع:2 , ٠030111319‏ .. وضبط مسار ملف ال االا. 


2 - (811_غأع6© : وفيه يتم البحث عن برنامج النوتباد ضمن التطبيقات 
التي تعمل حاليا علي النظام .. وإتيان معرف التطبيق للنوتباد. 


3 - 5361 : وبه نقوم بالحاق ملف ال اانا داخل برنامج النوتباد. 
4 - !©2613 : وبه نقوم بفصل ملف ال اانا عن طريق البحث عن 


القوذيول الخاص تملف ال لان واننات مقيض المفذيول .فقن لمر 
إنشاء ثريد داخل برنامج النوتباد وبه نستدعي دالة /86ءطناعممع 


ونمرر لها مقبض الموديولك لملف ال اانا. 
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وننتقل الآن لكتابة ملف ال 1ا0 .. اسم المشروع سيكون [1ا6كامهفا] 


األ.لالاكاممط /17/ 18 ا 


وشفرة الملف [4510.اا(ا»1001!] كالتالي : 


2.3265 1 
أعلصم منمممعم غئط 2ت لأحعلط5 ,غأهقا]ا اعلصص 2 
عملا أكمعه عدتع ‏ 11116 0]ت11ا 2356 ١11لااآتزم‏ 2 3 
4 
عاحلل ناما دات علعبااء1 5 
عطل 2دتنعكبا عاساعم 5 
عطاك تاعصعها علساعم1 ؟” 
عضا كخم ععبااعم1 تخ 
1لاقة, كط لعة ل اكد أعقصم ا 32 ركعقخصل :نا ععبلاعمر ت 
لا1 
طلا 2ت مكنا طاتأعاساعمة 11 
دنا 2 تاأعصيعها طاتاعلساعمة 12 
دزا ةدتمم طاتاعلبداعصة1ة 13 
14 
ااانا لاانا: , اخ انا اانا : , نلعانالاانا: ,للغانالالانا: لاالليص عصعطوصنتذك 15 
اانا لانا: , خالا اانا : , لالخالا لاأنا: ,لالخالا لالانا: لاآلاجانم لاناضانا! 15 
انالا ن!: ,ناغانالاانا: ,نلغانالالانا: لااللعطص [نشكيعاموتم 17 
فالا نا: ,نالا لنا: ,للخالالاأنا: ,لاخالا#الانا: لاآلاغان عضرط_ضيط 1353 
13 
3أقل. لات 
لا" انام وداتاددل ا" دحال 12 مصم_ ‏ 21 
لا,"355|-"|اناعاددل"” حال عددةلكاددة| ‏ 22 
لا,"اافعتعوب" دحال 32عدلا_ ‏ 3ت 
لاء" لاانزمطعودومم ام" طل ‏ لعزم طعوددودما'_ ١‏ 4ن 
(لاأترياك ككع حال ابلاط 25 
اد ل ل لله للد الل لي لله لل الي ليلب ل الول لي لبه ل اليل ل الل اليل لي لق ل ال لي لل ل ل ليل لل 73 5-6 
*313ل. 27 
"ا" ووكععمرطط ‏ 233 
2 للك لااتقطءط ‏ 23 
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30  طاسادتااع‎ 001 

ليل بل لل ال ليل لله للب ال لي للد لم ال للق للد الل لي للق مل ال ليق للق ال ال ليقي ل لو لي لي ل 51 

علمع. د 

لاما اانا صددمع سنك ,ع لكام | 15 :معدت أكصاط عمنمر متا دعاانا 33 
نا اانا مم تعخص ممم 34 

للاث | اش_ددع_اناتاط_ ااناع دتصصدودعم نلا 11. 55 

ععدة كد [دا تأكناتر 3 

دوعن ناذا تزملز 37 

عد امعط 1 امه أآامعمع سوملم 38 

ولام اال الكاىة#تع, ا انالكام اال الكل تمعءطا | عامع رن ععاموينر 39 

لاا تدع:ا! خانانات الك 

لات | عانا_دذوع_اناط_ ااناع ع حرودمع متكا [أأعوات. 41 

ب( "معناعتاعك اانا" 1211 ام االالكاىتمععودددم" عيعاوين] 4 
“انا_طامارزل [1/١‏ ا 43 
االداة. الا 

علا ا ,بجع مسودمن 45 

آعم ضك 

اعوط بتطأصعاانا مك 


لل لل لاد ال لي لله لاب ال ل للد ل ال للق للد الل لي للق لل ال لي للق ل ل ليقي ل ل ل 7 45 
عولط عمط لقص مط 1 تك 
اشأ لبان اك لباك , تالكا , لانالكا يككععص نطلا , الاناصك؟ ععامسصر لاك 
آعم 51 
لارالخاع عم ءادصا 52 

ل لل ل اي ل ل ل ل لو ل ل ل ل ا ل ل ا ل 000 
لللالطنا: ‏ حص مع صل نا الالالانا: أخصاط عصومع الاناصانتم ‏ ك5 
اانا اانا نخدحا ام ا ا انا لا انا مدصنا 5-8 
#اكدكث | الالكاا :دب اقنالا ا ك5 
ااانا تصشفط اقنانا | 
حاذا"ا: يكت اقنالا ا 


كد صا 


ل- دنا 


ذأ 
إل 


كدت | لانالنابا لاعت 1ك ععاططء, دمن توكلم لاض 

بار ]ع طلا _ كا نرم لمات باع للما_ كا ,عابات من نولم 51 
حاط طإعصناا [ طاذعطنا ,عصع عم شختصام| عممد توكلم 52 
االالكارةءنتعوا_اطاء, عن نوكم 5 

ا الالكارة :ع عصم لاحت عمند ماكر م5 
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أكطآذا تأكلاتز 55 

عحعحاة دمحا عنتذ تحزمحر ذم 

تتارعصحناد ءوجاعدط ححا عنمن نوكر 5 

اال الكارعتمةلة لاضع “اعكدم|, عمنة صلم 5 

عصةكادددا 1 ادغ لا رعددةلكادكةاندكم|, عنم تانوكم 59 

ذخات[ اتا[ إنانات_آناآ, ا الالكار تدع عتما ععامجصنر 7 

67 ,حندعاطا عمط نوكر 1” 

6 ,للاكدندع[اطا عم نوكر 972 

لاا ناث_ ناآ ا الالكاى ده التقتما ععامجنر 73 

عام احات لاطا نمؤملل 7 

متنا العامة و«عدددا رع أواومه عياموجنر 75 

م 

بعتدةكاددة ا #اناناتك, لال الكائزع #شخد كص #اتتعادع :ا عا الائيالة1 1 
لاسا ]ل؟ا] اناا |_كتبر عا ! ترزحرت #انانامض 72 
, ا الاش طناعكلا_ ناتف , | الاقععناعكلرا_لااا 07 
االالكا م 51ئ1تام لكام ا الالكا,رلاكح,لاناك اك 
لقع اصشخط تضكر 831 

بتار لماك_ اباك , لداشخط , تصاعصط ا سنتصواك عجاوينر 3 
لعكتكطا , متصاعصم تتم غدومنا ععاموجنر 53 

كت 

عا | ا |1!الا. 35 

لارلا, االال؟اروكم #اناناظ ,عقدددع مامه عيعاموجوسر ك3 
زعدع!) 1. “اقح بانا. 3 

وك #اتاناظ ,عودددع ]ماع داحدد١]‏ ععامجوضر 58 

وخر #اناجلظ ,عودددع ]احا 6دموانا ععامبجن] 859 

ااال ]لذ ا. 3 

كمة خطنت؛ وكلل بقع ملم 31 

اعم 9 

ترعضع ااناصتئئك 3ت 


له ليد لي ليل لل لاد لي لي الله ال ليل لي ل الي لي لل ل ال لين للد ل ل لين للد ل ل ل ل لل 1000 1ك ا 
بلالا لاانا: ودا"ا ,ااانا عصخاطا عمنرم عمطوصبتم ‏ 35 
اناد :دنا اانا لاانا: رد دمب 9 
دا “ا, بتجع لور 9 

اشع _)_المابتبا- ديزوم 11 953 
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لمزم طعودددماما_ الوم دتعدلا_ ملعت [مخواودنا عجعاموسجضر 99 
عصعط_صبط العامة 1101 
كنم | طغنا_اماتبا- حيزوع 511 1ا. 11 
لارءمعغط [ أورع ععاوسس 102 
ااذالكا بعودددع |1" اراوذجمع عجاوينز 13 
5 اا. 14 
تمةقط| ,حمةقطس رودا عصختط ,عصره نتصاعطتتاعنا ععامجنر 105 
1نالكاطا. نا1 
اعم 117 


تراعدع عمءطعوصنتا 103 
لل ل لاد اليل ليل للد للب ال لي للد ال ل للق مل الل لي للد الول لي ليلد ل ل ل للد ل ل ل ل 119 
لمالا اانا داحاا_حاء نا انا لاانا: نال شلاكح_ذا عصام عصزط_حيظ 2 110 


انا لنا: 3 نا انا لاانا: عا 11_لا 111 

ب اانالكا غنم ععودددعامن عجعامبن 00 

"فرصلا أ مختصلاك. ,الها مصاغعصيظ لتفععاددت ١١‏ | ) 11 
زالكاطعك_طمارل )| ا 114 

055 -ح بزوهع 1ل 00 

15,عا١‏ 11 _طرتاكا"ا_حام الكل بتتبزمععودوددعامن عجاوبنر 11 
مجع 117 

نالاانا1 ب “مرجع متولر 113 

اعم 113 

أالناع. نا-1 

اعم 1531 


تزلديع عصضعط_صيظ 2 1232 

ا ل ل ل ل ل ل ل و 0 1-3 

نا اانا : حصا عصبظ ,نل#انالالاناءعم دا"ااانا عمنم [نأشئادمآ 124 
انالا نا: دعت ننم" 1-5 

لاخالالاانا: امعان تاوت اشنالاا 1 

لاعانالاانا: مدضواتنت اقنانلا ا 12 


1-5 

انالك دع عن 3ا|"ااانا 11 125 
اترع_ فاع 01]زلاز 1310 
أالدع. 131 

00 
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الاك تت ررماعريظ آّاء 1133 


اصلاع_ تناع تزؤللال 134 
آالدع. 135 

35م 

اانالكا دح معت ضنصل" 11 137 
اطغلاط_ باع تزالاز 135 
آالدع. 133 

لالىك1 


عدم3ا"ا انار عاتصد تاماعد “اعد ععامطمر1 141 
االالاا -عح بزهع  .11‏ 142 

االلاع_ لجاع 11]1از 14 

أالدع. 144 

تاداع لاا قمر ددع ععشضعءد إططاعنا ععأممطمرد 145 
االالاا -عح بزهع  .11‏ 145 

اصلاع_ تناع تزللال 147 

1453  .عولاأ‎ 

بتع , اععضشوارت نمدم 149 
ااامالكارعاعصوتاعاباعدا“ااعى ععاوسجصر 151 
االالاا -ع بجزهع  .11‏ 151 

امغلاع_أاباع تزؤالال 15 

[1الدع. 153 

54م 

نمع , عاب عد "اذا سمدم 155 

عاعد “اط بزاع سمدم 15 
اعناقعلما_ذنارنا_عاجام ]1 نامر اامع عصوباجودح 15 


155 

علا اخ لاتاد_ذنانا_عطنات "!1 -! عأوددرع. [االع] 11 159 
اطلاع_ ]تناع الالال لا1 

االداة. 151 

15 


بتتعودأا_ع. [اللع ]| ,رعمع سصدم 153 

تدع ,ألمع لله 154 

32 ناشعل]_ آلظا_عاوام "!1 ادر :المع عدصربادوود 155 
15 

انا [ شلكات1ك_ [لذا_عنات "!1 دا علطادتدواد . [اانع ]| 11 157 
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اتع_ اماع 1]01لاز 155 
[اللاع. 15 
لا 1 


مقع أقحد طامنا [اامع ]| ,تلمع همعا ‏ 171 

2ت ناشع لا_ اشالكات] [ طف_ عانم »1 ادر ب«امع علوباعودح 1 
لاإصطاعق نات دنا [ :«امع ] ,ج«لمع معا ‏ 173 

لان [ 2 [نا_ثت ا ذنا_عطوات "1 أمععاه ,جاع للدت 174 
اانا 1 اع آنان ثم ا شنا_طاوام "!1 نامر :ججامع عدصرباددح 15 

دتة العلعشف أدبلا [جاعع |, لماع عصرم 15 


1 

االالخ --ح يتلمع 1ق 15 
انرع_ اماع لزالال 179 
أالدع. ‏ 130 
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عاباتد "اط ,المع نموم 2 132 

لمع ,المع للم 133 

نا | ع[ _وعنا_ [ لأنادم"]_عادات "1 أم: المع عدبيدوة ‏ 134 
لا -! 3121ل" [ الع ]| عاتطس:. 135 


عاناعدماط ,عع ووم 136 

1عصمدخ"ا. [اامع] ,عع للد 1537 

علدا"ااانا بج«امع سمدم 138 

لاع تع أمموع موا عجامبدرا 139 

لا -عح بجزهع 11 10 

ادع انا 1131 

االلاع. 132 

نا | ص[ا_اطعنا_ [ لأنهلك"]_ امات ل"1 أمعجاة ,لامع علد 103 
ملال0)ززع. ‏ 134 


“اباط [ غ5 [المع ] ,زامع سمدم 155 

عاعدماط ,امع ممح 16 

قا ذرنا_ةال لات _عنام 1 أنر:زامع عدصربادود 127 
علا عانحاعب. 135 


لا <-! [لامع] 11 139 

زأالع] ,لمع جمدم لالات 
اداعفواته - - بارع 11 21 
زانع] ,بتاع مما لات 
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بكرنطاع عأععامءطادبط؟را؟ ععامسضر 203 

ب 11 اناشععم_ع ا لا_اعماع_اداشنم لات 
أعع ام رط ونا المح كات 

لدعت صل" , تمع نودم نا2 

تدع ,[بعطع ]| 1 2 رطان سووم 27 

بذ ةداع ادعام طادبط/؟ ععامسسر 2 
أععخصناوترن لأعاعم أعععمعطواننا «علمةح 2 
55 الاك_ اتا 11]1ال لات 

الداع 211 

االلاة. 50 

3 ,المع علوت 213 

رارك 214 

2 


:55 االاط_أأناع 15ت 

,مجع بإولر لت 

اعم 211 

: املاع_أاماع 13ت 

م دقع الا ناث 

آع الس 

مدع [طخؤادممل تنمت 

ليل ليل لباه الل ليل لبلب ل الل لي لبه ل اليل لي لل ال ليل ل ل الل ليل لل ل اليل لي ل ل يلو د 
با دحااانا مووعط ك4ضي 


سنقوم داخل مكتبة ال اانا باعتراض الدالة "/لالا80 1155306" داخل المكتبة 
"5632.11" .. هذه الدالة هي التي يستخدمها برنامج النوتباد لعرض 


السطور 40-38 : نقوم بإنشاء مسار تنفيذ داخل الموديوك له بعنوان الإجراء 
ع30810ع1] | . 


السطور 52-49 : شفرة الإجراء 1163080 وبه نقوم بإستدعاء الإجراء 
اا صآلانا. 


السطور 93-54 : شفرة الإجراء 1اا30الالا .. وهو مسئول عن إظهار نافذة 


10010 بسيطة للمستخدم لن نستخدمها في شيء سوي للتأكيد البصري 
.. ولعرض طريقة لسير العمليات داخل الموديوك. 
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السطور 108-95 : شفرة إحراء النافذة ع]لالع206 /150011/لا.. وبه عندما يتم 
إنشاء النافذة يتم استدعاء الإجراء 0088[1!! لبدء تغيير عنوان الدالة 
//ا»ا80ع1»5530/ إلي عنوان الإجحراء©20_(الاطآ الموجود لدينا في الموديوك. 





السطور 122-110 : شفرة الإجراء ©2]06_(الاطآ .. ويستقبل هذا الإجراء 
المعاملات الممررة للدالة //)“ا0 ١1553068‏ ومن ثم يخيرك بين عرض الرسالة 
او لا. 


السطر 124 : بداية شفرة الإجراء آملظلامولا. 


السطور 141 -149 : نقوم بالحصول علي عنوان الدالة /لالا1»5530680١!‏ ونقوم 
بتخزينه في المتغير المحلي 01108001 .. وسنستخدمه لاحقا للمقارنة. 


السلور 155-350 © الخصول علي يذانة فؤؤيوك يزنامة التؤتناة في الذاكرة. 


السطور 180-156 : نقوم بالوصول إلي عنوان /9إ101أ©03131016 تم نضيف له 8 
بايت (حجم العنصر الأول) لننتقل إلي عنوان العنصر لإ61]01ع01آا 170011.. ومن 
ثم نحصل علي العنوان 14312001655/ا والذي يشير للعنوان النسبي لبداية 
البنية 1112011_105501121014_ع 40م !1. 


التمتهلو 18531837 نفو ون يف ها كران لكل فلك ام داخل المصفوفة 
2_1012081_05508 11186 .. لحين الوصول إلي الملف المطلوب 
"5632.0" .. وعندما نصل إليه نقوم بالخروج من التكرار وإتيان عنوان 

»| انال 1 ]15أعا والذي يشير إلي جدول العناوين للدوال. 


السظلوو 144186 2 :ونين ثهر تقوو رقمل 'لكراز خاخل حدؤول العناوين اللذواك 
ومقارنة العنوان الذي لدينا 011960017 بالعنوان الحالي في الجدول .. لحين 
الوضوك الي غنقات الذالة القطلوية بن قعندفا. رضل اليه ور خضل علي موطة 
هذا العنوان ونخزنه في «0ع ومن ثم نقوم بتغيير حماية الوصول إلي موضع 
العنوان وإتاحة الإذن 2112 /الامهعه_ع1لاععاع_عو مط بالتعديل .. ومن ثم 
نقوم بنقل القيمة الجديدة للعنوان الذي نريده 0/2/8008 إلي موضع 2ع .. 
دمن تدر اعادة حمانة الوصو قرو أعرى كما كانت 


وللتجرية قم بتشغيل برنامج النوتباد واكتب به أي حروف .. ثم قم بتشغيل 
برناهه كقن هلف الدنلانا ى. واضفقط نل قااف .فسن يمر فوونفلق :ترناقة النوتناة 
لتظهر رسالة "هل تريد الحفظ" .. وسيقوم البرنامج لدينا باعتراض هذه 
الرسالة.. 
ؤيمكن حقن ملف ال : :انان فى «خمتة التطبيقات»تواسظة الطريقة الناتية.. 
واعتراض العديد من الرسائل بهذه الطريقة. 
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الفصل السابع 


برهجة الشبكات 


1 01:1 تاكاه احا 


1. المفهوم وكيفية التطبيق. 
3. شرح شفرة البرنامج. 


- المفهوه وكيقية التطبيق 





في بداية هذا الفصل لابد وأن نتعرف علي أساسيات برمجة الشبكات .. ومن 
المؤكد حاليا أنك تعرف ما هي الشبكة /01//ا8/6 .. وأنها عبارة عن مجموعة 
حاسبات متصلة ببعضها تقوم بتبادل البيانات فيما بينها .. وأنه توجد عدة أنواع 
من الشبكات مثل الحا اختصارا إلي ١/650/011[‏ 8:63 ا3ع0ا] وأيضا النوع 
ملالا اختصارا إلي [0:1//ة1١‏ دع:8 ع106/الا] .. وأيضا شبكة الانترنتغ+©10161/0. 


ولتكوين الاتصال وتبادل البيانات تعتمد الشبكات علي بروتكولات0]060|5] 


البروتكول : 
عبارة عن مجموعة من القواعد التي تتحكم في شكل وصيغة 
السبات القهررة على الشكة 


فالبروتكول يحدد كيفية الاتصال بالشبكة لكل الحاسبات .. ونحن ملزمين 
باتباع تلك البروتكولات إذا أردنا إنشاء اتصال وتبادل بيانات ناجح. 


وتعتمد الشبكات علي عدة طبقات من البروتوكولات 5/علإ3 ا 2]0]0©0١|‏ .. وكل 
طبقة إعلإ3 ا لها مهمة محددة في الاتصال .. 


والشبكات الشائعة هي شبكات الايثرنت المحليةاقا أ©6]عا]ع .. والتي يتم 
توصيلها بكابلات 12لا أو كابلات ألياف ضوئية 2166/6 |0063 .. وشبكات ال 
5 والانترنت تستخدم كتثيرا من التقنيات المستخدمة في شبكات 

ا أ©15ع0]ع .. وتتكون شبكات الايترنت من عدة طبقات هي "كالتالي : 


طبقة التطبيق “'ع/ا3! 011311011م82 : 

وهي الطبقة التي يتم فيها استخدام برنامج 5010/0/3 للاتصال بالشبكة 
ويتم ذلك عبر مكتبة 482815 15506©1//ا والتي سيلي استعرضها بعد قليل وتتيح 
المكتبة التعامل مع الشبكات بكل سهولة..بدون الحاجحة للقلق حول الطبقات 
المتعددة والحزم ك5أع2301 ومصير البيانات المفقودة 101]م0110) 0318( وإعادة 
إرسالها مرة اخري واشياء اخري عديدة. 

: 113115001 ٠ #/ل3‎ 

الطبقة التالية هي طبقة ال 162 أو الطبقة البديلة لها 02لا وهما طبقتين 
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امعمخمع8 أمعخامه») 0و5 ماك 1 
امعممه ورة 2336 :ع5لا 


حيث يوضحان كيفية سريان البيانات علي الشبكة .. فالبروتكول مى| من 
معامه التأكد من وصول البيانات إلي المستقيل بصورة سليمة .. وإذا لم تصل 
بصورة سليمة فيقوم 1052 بإعادة إرسالها مرة أخري .. ويستطيع المسنفسل 
التحكم في وقت إعادة الإرسال مرة أخري إليه .. وكل ذلك يتم التحكم به عبر 
مكتبة >ا|©1]7506/الا. 


بينما طبقة الا مختلفة قليلا عن 162 حيث لا تضمن بروتكول 02لا وصول 
البيانات بصورة سليمة. 


ويتم تحديد رقم المنفذ غ201 في تلك الطبقة .. 


رقم المنغذ اع1112نالا +20 : 


يستخدم هذا الرقم لتحديد أي تطبيق يعمل حاليا سيستقبل البيانات .. 
ورقم المنفذ يتكون من 16 بت .. وبالتالي الأرقام المتاحة في المدي من 
صفر إلي 35.. . وتوجحد منافذ محجوزة لتطبيقات مشهورة متل المنفذ 
رقم 21 ل 18 , رقم 25 ل 5117128 , رقم 80 للمتصفح .. ومن المفضل أن 
نختار رقم اعلي من 4[ظ[ظ/1 .. حتي لا يكون رقم المنفذ مستخدم ٠.‏ . ولا 
نستطيع في هذه الحالة إنشاء اتصال عليه. 


“اع/[3 ٠‏ أ111ع1111 : 


بعد ذلك ننتقل إلي طبقة الانترنت والعنونة 8001255150 حيث يأتي بعد ذلك 
عنوان الانترنت 12 اختصار ل |2000 أ1ع]11. 


رقم الانترنت 11011121 159 : 


هو رقم مكون من 32 بت منقطة بالصيغة المشهورة [48.15.16.32] 
حيث كل خانة تمثل 8 بت .. تاخذ قيم من المدي صفر الي 255. 


ويتم استخدام رقم ال 12 الفريد لتحديد جهاز معين متصل بالانترنت مع رقم 
الماك 6ىم/ل/ا. 


ويقوم هذا البروتكول بإضافة عنوان الانترنت للراسل والمستقبل في حزمة 
البيانات بالإضافة إلي معلومات اخري مثل إصدار البروتكول .. ووقت حياة 
الحزمة 23601 وستموت بعد تجاوز الوقت .. وكذلك إضافة ترويسات 18306/5] 
للحزمة وأشياء أخري لن يهمنا كثيرا ذكرها. 
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3/1 | دوع ©5226 )011 نلاأعلا : 


وهي أخر طبقة من طبقات شبكة !]5 .. وهي طبقة ١131011/316‏ ويطلق 
عليها ©1186 أو ؛علاقا و5عع©8 116013 .. وهذه الطبقة قد تكون كارت شبكة 
210 قا أعماع٠ااع‏ .. يقوم بتحويل صف البيانات إلي إشارات الكترونية ويقوم 
بارسالها إلي العنوان المحدد. 


ويوحد عنوان رقمي فريد للكل 11480 علي الشبكة .. 
رقم 1186 : 


رقم فريد يتكون من 48 بت يستخدم كمعرف لشريحة الشبكة .. 
وهو يكون علي الصيغة [04:08:15:26:23:42] حيث يمتل بأرقام 
“© في كل خانة .. ويتم فصل الخانات ب":" 





1ق ا كاه تأمت ا امرمرف 





© الاتصالات 011116©110115) : 


يتم الاتصال باستخدام بروتكولي 1)8/12 بين جهازين علي الأقل .. كل جهاز 
له عنوان الانترنت والمنفذ الخاص به .. والمعروف ان يكون جهاز عميل امعان 
والاخر مزود ]اع/١]561.‏ 

10ظ1 


العميل غ:116© : يقوم الاتصال بالمزود :560/6 وطلب البيانات. 


المزود ”علاازه5 : يقوم بالاستماع 0(أمعغ]دنا إلي أي اتصالات قادمة أو 
اتصالات محددة 011611005 أدوعلا0ع 176011717170 ويقبلها أمع866 .. ومن 
ثم يقوم بتنفيذ طلبات العميل وإرسالها له. 


ومن هنا نعرف أن العميل هو الذي يقوم بطلب بيانات .. ومنه يقوم المزود 


علي سبيل المثال عندما تقوم بفتح صفحة موقع .. المتصفح الذي تستخدمه 
هنا سيكون هو العميل ]110 .. ومزود الويب /6/ااع55ع/لا المحجوز عليه 
الموقع هنا سيكون المزود اع/١]ا5.‏ 


وهنا يكون ال:60561//6/لا في حالة استماع 1561| لأي طلب اتصال به. 


قم مثلا بفتح موقع جوجل .. ثم قم بتشغيل 0110 واكتب الأمر التالي: 
0 6153م 
وستجد من نتائج التنفيذ السطر التالي: 


عع . ل لرعاث 3 لمع اكرها 5 الا 0انال! للا؟ ٠:‏ ١ه‏ 


192 1598 1312455 85 170146 4 85 1011:1110 


: 5 
الا ةا 1101 _ 29 _ 5م ونام نايا قاد امقد اه 
عد عد 10965 :ا ذا _ ةا _ قر 
عد عد 7 09 1 : نا _ ا _ ها _ قر 





ماع ك1[ اظلم ]| 5ع 0 2< 110 0 85320<م- )| 


قهة سحنة نوغ المروتوكول الممستهرمر 7678 تدر هنواته الاشرتت: الجالفي لجهاز 
العميل 1160© ورقم المنفذ المستخدم في إنشاء الاتصال لجوجل .. وهو منفذ 


عشوائي ثم عنوان جوجل الذي رد علي طلب العميل .. ثم رقم المنفذ الذي 
يستخدمه سيرفر جوجل وهو 80 .. وحالة الاتصال 560ؤذاطهاوع. 


2 مقابس الويندوز5اع»50©1 11101//5لالا : 


ويطلق عليها وينسوك 1ا1//17506 كاختصار .. ولتعريف ما هو المقبس 5001 
فكما تلاحظ يقوم أي اتصال علي وجود طرفين .. كل طرف له مقبس يمكنه 
من التعامل مع الطرف الأخر .. هذا المقبس مرتبط بعنوان الانترنت 12 ورقم 
المنفذ غ01 .. ويعتبر مقبض للتعامل مع الطرف الأخر. 


والمقيين:تفسيه ذو اتحاهين .. يمكن إرسالة.واستقيال البيانات تواسعلنة: 
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: 50014_511880/1- 1 

وهو يستخدم في التطبيقات التي تحتاج إلي اتصال موثوق فيه 
كن لل ور 010 رنحيك عتدف نتم رسا سر ون ابارت 
تصل جمعيها إلي المكان الصحيح. 


2 - لاقع 6ه_)ا50 : ' 

وهو يستخدم في التطبيقات التي تقوم بإرسال الصوت او الصورة .. 
اي يعتمد علي بروتكول(الا بحيث لن تؤتر عملية فقد البيانات علي 
المحتوي بصورة كبيرة .. فهذا النوع من المقابس يكون اسرع من 
التوع الأول.,. ولكنه لآ يضمن أث صل السانات إلى المكان الصعة. 


© إصدارات الوينسوك : 


يوحد عدة إصدارات متل : 
0 اع50 ملالا 
1 اع50 ملالا 
0 >ا6ع50لألالا 
اكثر إصدار استخداما هو الإصدار الثاني 2.0 وهو يدعم الأنظمة التالية ,98 
02 مع" .. وحزمة 11451132 بها كلا من الاصدراين 1.1 2.09 


50132.01١‏ .506132 نثارعطا. 21/506132 : 32-81 1.1 أعاع50 3/5ا00 ألا 
١152_32.01+>||.1/52_32ارعطأ.1/52_32‏ : 32-81 2.0 أعاء50 0013/5 ألا 


وسنقوم بالتطرق الآن لدوال الوينسوك 821 ا157506//ا التي سنستخدمها في 
عمل مشروع أعلناتاع5/اأا11ن). 


1 - داله مب :ج5851ثلا 
هي أول خطوة يجب القيام بها قبل استدعاء أي دالة أخري ضمن 
المكتبة .. حيث يتم استدعاء هذه الدالة لعمل تهيئة لمكتبة الوينسوك .. 
وللدالة التعريف التالي: 


ناملا ناد تنام حك نكم| ,رافلا نا :نع عد عروع اممادمعنان لا[ للطظ مبطءةعاكتركنا 
نلاحظ وجود معاملين لها .. 
الأول 0ع6دعنانع51011:علان/نا : يحدد إصدار المكتبة المراد تحمليها .. 


حيث يتم تخزين رقم الإصدار الرئيسي 13[01! في البايت السفلي '"ا0 | 
'ع010 وتخزين الرقم الثانوي 1/1501 في البايت العلوي :010 داأوط1ا. 


02ظ1 


الثاني 5810383ل/الام! : مؤشر لبنية والتي تستقبل 
معلومات عن المكتبة التي تم تحمليها بعد نجاح الدالة.. ومحتوي البنية 
كالتالي : 

117 5 5410418/لا 

و ماللا 0 داع اناا 

و مما للا (ممزدمع/اطوالاننا 

(2) مبال 1 + لاع ا_/10 250112110 رامك/لا ع[ ل/ا8 اكه وقتت 318 

(2) منال 1 + للاعغا_كنا1 18 5_كلا5485/لا عا لا 5لاأ82أ5(اع]و5ل!525 

9 ماآلكامنا كأعا ه350 |/] 

27 جاآكا0/نا وماملناء<ق |/ا| 

37 (اثا0/الار] 0110ل معثام| 
5 61 رامر5/"ا 

ويمكنك قراءة محتويات البنية لمعرفة المزيد عن مكتبة الوينسوك المحملة. 


وعند نجاح الدالة تعود بالقيمة صفر وإلا ستعود بقيمة غير الصفر تشير إلي 
فشل الدالة .. 

يمكك الاستقاذة الفبعة التى عادت:] ذا فلت الدالة ومعرفة السيت البحة 
عن معني تلك القيمة في ملف [10/100010/5.176] فقط ابحث عن النص "58/اا" 


للوصولك لبداية تعريفات توابت ت الوينسوك. . ومن تم معرفة الثابت النصي 
المقابل للقيمة الرقمية.. ومن النص يمكن الاستنتاج بالسبب. 


كن فى.معظير الأحوال سكتحة الذالة ىن قلهر تقش :معي نوما 


2 - داله مباتاردجعء2601ك5ثلا 


عند الانتهاء من استخدام المكتبة .. يتم استدعاء تلك الدالة لمسح 
المكتبة وحذفها من الذاكرة .. وعن كل استدعاء للدالة مل58531//ا 
يجب ان يقابله نفس العدد من استدعاءات لمنام3ع5/801/لا. 


10110يظ مسامقع| تكبا 
والدالة ليست لها معاملات. 
3 - داله غأعغ1 50 
تستخدم تلك الدالة لإنشاء مقبس جديد .. وتعريفها كالتالي : 
نا لا نا ءادح دات ,نا ناملا نائعما_دنا هنا ملاناءعم لااللصط أعاءهه 


للدالة 3 معاملات هم 
33ظ1 


الأول 5ه : يحدد عائلة العنوان لإاأم:3] 2001855 للبروتكول المراد استخدامه 
ولاستخدام البروتكول1©22 أو 06لا يجب أن تكون العائلة هنا هي2_1(0181ث . 


الثاني 6ه لإآ_5 : نحدد نوع المقبس المراد استخدامه إما 5001_5141 
او 5001_0141 .. وسنتعامل مع نوع المقبس الاول لاسباب سبق ذكرها. 


النالث 2808001 : يحدد نوع البروتكول المراد للمقبس استخدامه 
ولاستخدام 125 .. نضع القيمة هنا 1080010_726, 


وعد تجاح الدالة تعوو يمقيض للفقسن الخديد الذي نهر إنشانة .وال ستهؤة 
بقيمة .1(/١/8110_506©167‏ 


4 - داله أع1 6105650 
ومن اسم الدالة نستنتج أنها تستخدم في غلق المقبس بعد انتهائنا من 


استخدامه. 
اانا اناه لا [اللطط ععاءدوعدجماء 
لها معامل وحيد وهو قيمة المقبس المراد إغلاقه..وعند نجاح الدالة تعود 
بصفر وإلا ستعود ب5001)21_1101. 


50123001 - 5 


بروتكول 102/110 يستحخدم رقم انترنت ورقم منفذ للعنونة وانشاء اتصال .. 
لكن من الممكن أن تكون بعض البروتوكولات الأخري لا تستخدم نفس 
الطريقة .. وللتوافق مع جميع البروتكولات .. ففي النسخة الأول من 
الوينسوك .. تم حل هذه المسالة مع البنية 50613001 .. 


1الا18 5 اللكحاءده 

7 لانامكة ‏ ب ازوت]_ده 

(* دنال 14 غ891 تأدل_ده 
كنالناع كاده 


العضو الأول في البنية “,5021300 هو [الإاأماة)_53] وهو بحجم 2 بايت 
فس كرو رقف تكن قائلة العندات الغنوان لسع دن بس لهال 


العضو الثاني هو [53_03]8] وهو بحجم 14 بايت ويستخدم حسب 
قواعد البروتكول المعمول به. 
1604 


ل 
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ومن ثم فنحن سنستخدم عنوان عائلة 100/158 .. فيوجد تعريف آخر 
للبنية السابقة خاص ب1)8/12 وهو : 
1 الا518 مزل لكناءده 
2 زنراملا “ازلدمةظ]_دات 
2 لالالايلاة أءنام_ات 
جه 6للةت_مز “ّت_دات 
(2) نال 5ت 8591 ننعج_لزت 
ذنالئاط مزل لكناعده 
فالبنية 5061300110 تستخدم في تخزين عائلة العنوان ورقم المنفذ 
201 وعنوان الانترنت 12 .. وآخر 8 بايتات في البنية للتوافق مع حجم 
البنية 50613001. 


العضوبا!:510_13 : نضع به 8_10/251 لنتعامل مع بروتكول 1©8/16. 


العضو 6غ:0م_5190 : نخزن به رقم المنفذ .. ويجب أن يكون الرقم في 
صيغة 0101 عآلا8 1م نلتاع ل . 


العضو:51!11_300 : مؤشر لبنية 1_30017 بحجم 4 بايت لنخزن به عنوان 
الانترنت 12 .. ويجب ان يكون الرقم في صيغة /7ع010 عغالا8 1م نلتاع لا . 


010 عغألزة )1م اناالا : 


من الواضح أنك ألفت علي مفهوم ال 01066 8/16 أو ما يعني أنه توجد 
قيمة تخزن في بايتات بترتيب معين .. فمثلا القيمة [48151623] 
بحجم 32 بت .. تحتاج لأربع بايتات لتخزينها. 


معالج 86< اع10 يستخدم طريقة [050130ع-©11]) في ترتيب التخزين .. 
والذي يعني أن أقل بايت يخزن أولا .. وبالتالي ستخزن القيمة السابقة 
بالتتابيع التالي: 

486 , م15 , م16 , 236 
فمثلا إذا أردت حفظ القيمة السابقة في مسجل هكذا : 

30 <”«3»© /املما 


فستخزن كالتالي : 
11100 11تاألعدع-م1 !ا 
3 16 15 48 - يرمع 
3 16 15 48 - عم 
3 16 15 48 - ام 
3 16 15 48 -ت ام 


مك7 


وبالتالي البايت الأقل في الترتيب 2378 أو 35 عشريا تم تخزينه أولا .. 
وذلك علي معالج 86 اع10 .. بينما معظم المعالجات الأخري لا 
تستخدم طريقة [600130-©11!] .. بل تستخدم طريقة عكسها وهي 
باسمر [810-650130] .. واذا تم تخزين القيمة السابقة علي تلك 
المعالجات بهذه الطريقة فستكون التالي : 





230 , ط16 , م15 , م48 
111100 510-2101311 


8 15 16 23 -ح بإلم] 


8 15 16 23 - 6م 
8 15 16 23 - غم 
8 15 16 23 -ت ام 


وبالتالي مع اختلاف تتابع البايتات بين الأجهزة .. فيلزم وجود قاعدة 
تسري علي جميع الأجهزة .. وهذه القاعدة هي تمرير البايتات للشبكة 
علي طريقة [200130ع-510] 9 تسمي هنا اع010 عأالزظ8 1زم نلتاء ل . 
وبالتالي علي معالج 86<« اع]10 إذا كان لدينا رقم المنفذ وليكن [12341] 
او [4660] عشريا فنقوم بترتيب البايتات حسب 0104 عالا8 ملاع لا 
لتصبح [3412] ومن ثم يتم تمرير واستخدام رقم المنفذ[13330]. 


توحد دالة في مكتبة الوينسوك تقوم بهذه العملية وهي دالة5مماا 


6 - داله 5دداهمغاطا 


وهي تعني ]5101 101 م00 عالام ملاعل 0غ عالاط أ5مل أمع/امم ]| 
[1!5ع76الالاا .. وتعريفها كالتالي : 


نابل ]رم راعاددرا لا[ للطاظ عمصغا 


ولمافغافن محيد .وهو القيمة المراد تحورا ما .وثفوة الدالة بالقيمة 
المحوك: اليوا.وتوجة ذالة باسيهرز 1]0]16] تقؤعر يعكس تلك العملية: 


كذلك الحال مع رقم عنوان الانترنت12 يجب أن يكون في صيغة تتابع الشبكة 
ولن نستخدم له 1850135 بل دالة اخري خاصة بذلك باس م3001_آع©1:1. 
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7 - داله 3001_خأع1! 


تقوم تلك الدالة بتحويل نص رقم الانترنت 12 المنقط .. إلي قيمة بطول 
2 بت .. وللدالة التعريف التالي : 

اانا ملا نا:مه لا[ لاظطظ للت_ععما 
والمعامل الوحيد لها هو مؤشر لنص رقم الانترنت. 


فمثلا عنوان الانترنت "127.0.0.1" إذا أردنا تحويلة لصيغة الشبكة سنقوم 


بالأتي : 
10لمع-عل]! 10 هج 1 بد* 98 يي 0 ع 7 بل 
0 1لمع-عل]! 10 جه 7 ع ا سن 0 سر 1 
نم1 »اعط ة وموألمع-عءل]1!ا مز ه 77 . ط00 . ط005 . 01 


3 - 0100007 -1050 * ع + 10451 * 7 + 1656 * 1 


والقيمة: [167773343 ] هقف تفسن القيمة الى +ستحضا: عليها عند 
استخدام الدالة ,300_غ©10 مع العنوان "127.0.0.1". 


وتوجد دالة تقوم بعكس هذه الدالة وهي دالة2103_غع)1. 


8 - داله عاط 
تستخدم تلك الدالة لربط المقبس الذي قمنا بإنشاثه مع عنوان انترنت 
2[ ومنفذ 201 .. ولها التعريف التالي : 
ناملا نائمع اع اقم ,نالا ملا نائء111 تك ,اانا ملانا:ه لا ا للظظ لللط 
لها ثلاث معاملات : 
الأول 5 : ونمرر به مقبض المقبس غ5021©6. 
الثاني ©3111 : ونمرر به مؤشر لبنية أ50613001. 
النالت 23111611 : حجم تلك البنية. 


ونحتاج لتلك الدالة قبل وضع المقبس في حالة استماع 0(أمع]دنا لأي 
طلب اتصال قادم. 


9 - داله داعغ15 ا 


تستخدم تلك الدالة لوضع المقبس في حالة استماع ©5686 ”تاعاذا .. 
ولها التعريف التالي : 
7ظ1 


انال ناءودلكاءتط ,نلنانا ملا نا:ه نا لاط معادا 


المعامل الأول 5 : هو مقبض المقبس الذي تم عمل 0100 له. 

المعامل التاني 361100 : يخزن به اقصي عدد طلبات اتصال منتظرة لم 
يتم الموافقة عليها بعد.. ويوجد الثابت (ا[501181)001 كقيمة افتراضية 
ليتم اختيار قيمة أوتوماتيكية تبعا لمزود الخدمة. 


وغن تتحاغ الدالة قتعوذ بالقيمة صفر :. :هبد فشلها تعود بالقهة 
8مجمع_[7ع)5061 


0 «اله أمع©26 


تستخدم تلك الدالة للموافقة علي طلب اتصال قادم .. ولها التعريف 
التالي: 
ناملا نامع لت ,ناا ناملا نا 1تناعده ,نلالاملاناءة لا اللطط أمععدة 


المعامل الأول 5 : هو المقبس الذي في حالة انتظار و طامع]5ذا. 
المعامل الثاني 5061623001 : معامل اختياري ويمكن وضع 1 الالاا له .. 
ولكنه في الأصل مؤشر لبنية 5061300115 والتي ستحتوي علي بيانات 
الطرف الأخر المتصل. 

المعامل النالت:30011©1 : وهو حجم تلك البنية. 


وعندما يتم الموافقة علي الاتصال .. سينشأ مقبض لمقبس جديد كقيمة 
معادة من الدالة م3606 .. هذا المقبس الجديد هو حلقة الوصل مع الطرف 
الاخر. 


1 «اله أ©6ع0111© 
تستخدم تلك الدالة لإنشاء اتصال من مقبس لأخر .. ولها التعريف التالي: 
لاملا نامع اع ددم ,ناملا ناءء مهن ,لالاناملانا:ه لا[ تلاط عععصدمدمه 
المعامل 5 : هو مقبض المقبس الغير متصل والمراد إنشاء اتصال به. 
المعامل 113116 : مؤشر لبنية 5ض_50613001 بها بيانات المقبس الاخر 
المراد الاتصال به. 
المعامل 13111611 : حجم تلك البنية. 
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عند نجاح الدالة تعود بالقيمة صفر .. وعند فشلها تعود ب08ههع_50©1)261. 


2 - دالتي /ا6ع: :8 10اع5 


الدالة 0مع5 لإرسال البيانات والدال 5-3 لاستقبال البيانات 1 
الدالتين لهما تعريف متشابه. 

انا مانا ئدودا ,10 نا ليلا نا مع|! ,نالانا مل نا: آنا ,ل1انا/ملانا:ه 10 لالظ لمعه 
المعامل 5 : مقبض المقبس المتصل لإرسال البيانات عليه. 
المعامل #ناط : مؤشر لمخزن به البيانات المراد إرسالها. 
المعامل 0ع : حجرم المخزن. 
المعامل 41305 : معامل اختياري يتحكم في طريقة نقل البيانات. 


انا نك نا :كوت ,نلا نا ملا نائ دعا ,نللا نالا نا: اباط ,تالاناملانا:ه لا اتلس دعم 


المعامل 5 + مقيض المقسن والذق سبيستقيل التنانات عليه 
المعامل #لاط : مؤشر لمخزن لوضع البيانات المستقبلة به. 


المعامل 1©1 : حجم المخزن. 
المعامل 11365 : معامل اختياري يتحكم في طريقة نقل البيانات. 
عند نجاح الدالة 56100 فستعود بالقيمة صفر وإلا ستعود ب1_1101 500142 


عند نجاح الدالة )©60١/‏ فستعود بحجم البايتات المستقبلة. 


© 5أعغ501 ونكاءع10ظ نرهلظة ع8 ودكاءعها8 


الوضع الطبيعي للمقبس هو حالة الجمود 11006 81001 .. وحالة الجمود هي 
ان وظائف المقبس مثتل /15]61,6010©©1,5©10,1©©07! عند استدعائها فهي 


فمثلا المخطط التالي يوضح حالة التنفيذ عند استدعاء الدالقمع]ذذا 
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برمجة الشبكات 











ج12 1 اتلة أب 
لد 1 


111 0 1 
111 


لنجع 1 1 أتنة لام 


حر .ام 8 م 


91 1- 





حيث تم تجميد مسار التنفيذ الأصلي ودخلت الوظيفة ‏ 1667| في حالة 
استماع للأبد .. لن تخرج منه إلا إذا كان هناك طلب اتصال قادم.. في هذه 
الحالة سيعود ]لاأع؟ استئناف مسار التنفيذ الأصلي. 


الدالة 6007766 أيضا تدخل في حالة جمود إلي أن يحدث اتصال .. أو تعود 
بخطأ في الاتصال. 

حيث في حالة الجمود لا يتفر استخدامر ا اتبعارات 5 . 
فالاستدعاء يتجمد إلي أن تنتهي العملية. 


الاك ا لسك لحل ل ال الحم ف 1 والجاءة بضطلة 
وهي دالة 4عاء5 «لإوشث5/لا .. والتي تساعد علي إنشاء إشعارات عند 
حدوث أي عملية. 


3 - داله أععاع1165/ا[885 5لا 


تقوم هذه الدالة بطلب إشعارات رسائل النافذة لأحداث الشبكة علي 
مقبس محدد .. حيث تقوم بدمج رسائل الشبكة للمقبس مع رسائل 
النافذة 116553065 //15001/ل/ا .. ويتم معالجة جميع الرسائل ضمن إجراء 
النافذة ع]لال)ع206 /15001/ال/ا .. وللدالة التعريف التالي: 

انا ملا نا امع بع | ,مانا ملا ناءود اناه ,نا نا ئلا نا لم تخا ,مانا اناه لا[ألضسط عمعاعدعمبوعم مكنا 


المعامل 5 : مقبض المقبس المراد 


المعامل 70لالا1! : وهو مقبض النافذة التي ستعالج أحداث المقبس.. ومن 
الأفضل أن تكون نافذة مستقلة .. ويجوز استخدام أي نوع من أنواع النوافذ .. 
بشرط أن يكون لها مقبض 130016 مثل 013100 , “7/60 , وطاه6. 
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المعامل 1159ا/لا : تحديد رسائل المقبس بقيمة ثابته نقوم نحن بتعريفها. 


المعامل +1561 : يحدد الأحداث التي نريد مراقبتها للمقبس..وسنتحدث 
عنها لاحقا. 


وعند نجاح الدالة تعود بالقيمة صفر وإلا ستعود ب1_211018 50012. 


2 - قصدمهم م فاهيج .ره سرك //,رم:/7 








سنقوم الآن بتصميم برنامج يغطي كافة الدوال التي تحدثنا عنها .. البرنامج 
سيكون /]ع/011601/561 وبه صندوق محادثة بسيط . 


المشروع باسمرا17506/ا/ا والواجهة الرئيسية له كالتالي : 


]ع5 | أمعانا | 


لا 


أمصعانا د | تمعد إعمرع ذ د | لمعك 


8 





201 


والجدول التالي به أسماء العناصر ومعرفاتهم : 


امنض |0 عتتقلا | ه1 | # ا 


| 2016 | طلاللاللجع/588 | 2020 | 6 0 
| 0116# | لاغ1_الاعلك_آ0ضع | 1003 | 8 | 
| 20116 | اغآ +اع/ا*5_ا0ع | 1004 | 9 0 


أعتقد أن كل عنصر في النافذة معروف وظيفته ما عدا العنصريين : 
ملاللاك_للع611 
ملانلان_مع/امع 5ك 


هل تتذكر الدالة ع6ا056/إ5885// وأنها بحاجة إلي مقبض نافذة لكي 
تستطيع دمج رسائل المقبس مع رسائل النافذة .. فهذه هي وظيفة كلا 
العتضريين:: سعتضبحاتة كلا مدمما الناقذة الذي تستقيل: احدات المقيس.: 
وبالتالي سنحتاج إلي إنشاء إجراء لنافذة كلا العنصريين وهذا يتم عن طريق 
عمل ١10011150‏ علي كلا النافذتين. 





وقد قمت بدمج كلا من الكلينت والسيرفر في برنامج واحد ونافذة واحدة حتي 
يسهل ويوفر الشرح عليهما معا. 
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والآن نستعرض شفرة ملفعط7أ>اءعه50م للا 
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ارا كاكام لمات عنااعنم 1 

عماءةتاعمععنا علساعدة تس 

عماءةتعدن عسداعدة 3 

عاماء 32 ا دعصم عسنداعدر 4 

عماءت3أااعداء علساعدة 5 

عماءةتوكقم علساعدة ‏ 5 

عماءءت_نون علساعد م 

- 

طناءعتاعمعها طاتاعلساعدمر هه 
طللء تعدا طاتأاعلساعدة 10 
طناءةتااءواده؟ طاتاعلساعدة 11 
طلا 2ت أعداد طاتاعلساعدةه 12 
طلاء تت تدكقم طاتاعلساعمةة 13 
طلا 2ت_نتكثا طاتاعلساعدسةه 14 
ل 
تللكة, كص ءعقساخص دقصسمك 3ت مكعكخمات عسااعم 5[ 
1-7 
اتات ا 11/1 لات ,نال سخط: لاالتلهم عد وان 135 
ات “ات ا 1/1 لات ,نال سشخط: لاالتهم انزع مره5 2 13 
اتات ا 11/1 لات ,نال سشخط: لاالتلهم عمعصطعمعزات لاي 
لااناملانا: لا الاسم وصاسصطد ‏ 21 
عت 
أكااضع. ‏ ات 
1ل لاعت 1 داتاام[نا_نانا1 24 
101 لاع ع1_اوع ‏ عدج 
1002 لاع كتمتع_اوع مع 
10 لاع كبع1_الاعتت_اوع جج 
100 لاع آاع1_معتامعد_اوع ‏ سدع 
1005 نوع ككم]_الاعتات_اوع ‏ جع 
1005 لدع كم معتدعد_اورع 2 مت 
ل11لا1 ناوعت اع لةالكات__ل"ا ام 31 
1 لاع طلاع5_الأعتات_لرر8 2 2+ 
2 نالع ملاعد_معندع5_لزرم 2 3د 
1100 لاع 51_35]ا كد 
لالت ناومع نال شكلم الماع 1 35 
لاثلاتك نلاوع لاللاسشكط_شرع تسعد 35 


مك7 


١أنانا‏ ناوع 

داشنا لاوع 

1 + جأعكنا_الإبانا نامع 

ا ا با جا ا ا با ا باد ا باد جا وا جا جا بجا جا ا باب جا جا جلك با جا اد بأد جا بل ا ا 7 7و 7 


نا, 1لا ءناءمت 1" 
لالاكك 

[لا ونال 1ك 
)مسال نووكة 
اعابت 

نا "أععصصدم 2" 

لام "اع مصدعذوان]" 


حال 
00 
حال 
ال 
ل 
ال 
ال 


ا 
ا 
اا اناك_أ“انبابا 


513ل . 

1 

زوم 

بع اناا 

ادك | 

عم|ا اضاعل"ا 
الات _ا_نا1 
]181 اددذانا_نا1 


ططظط2<2: 


لل 


00 7 


ع هر | نر تركا 


00 7 
00 7 
00 7 
00 7 
00 7 


ومل_ لل كنادده 
2 مز_ءللكناعده 
2 مز ءللكناعده 


7 لل 
7 لل 
7 لل 
7 لل 


32ل 

ععمة اك نآلا 

واناطا 

تاق ناةذانا 

زعم دترا 

امع احا 

أكناطا 

نع رع وبع نام| 
امع اسع دما 

عن عت الل تناءدت 
امع اد للفضا-دد 
ععصووع ال لض دحت 
رع برك عدت 
أمعاععا-دد 
أعناء دامع ]ااا 
مال لضععمممرع همه 


4 ا 0 


السطر 14,7 : نقوم بتضمين مكتبة الوينسوك الاصدار الثاني. 
السطر 38,37 : نقوم بتعريف حرفي السطر الجديدعنا © ©©. 


السطر 39 : تعريف ثابت خاص لتحديد الرسالة الخاصة بالمقبس. 
لحمل معلومات مكتبة 


السطر 53 : تعريف بنية من نوع 
الوينسوك المحملة. 





3 
35 
33 
الى 
د 
4 
4 
كب 
300 
َك 
ات 
4 
د 
لاط 
51 
5 
5 
5 
5 
اط 
57 
52 
5 
لاك 
آ5 
55 
5 
54 
55 
ده 
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السطر 54 : تعريف متغير ليحمل مقبض الأداة/١/الالا_جاع/اماع5.‏ 
السطر 55 : تعريف متغير ليحمل مقبض الأداة2//الانا_12111ا6. 


السطر 57 : تعريف متغير ليحمل عنوان إجراء النافذة الافتراضي للأداة 
ملاللانا_جاع/اجاع5. 


السطر 58 : تعريف متغير ليحمل عنوان إجراء النافذة الافتراضي للأداة 
مانلا لاع 1©. 


السطر 59 : بنية من نوع (أ_50613001 لوضع بيانات مقبس السيرفر بها. 
السطر 60 : بنية من نوع أ_50613001 لوضع بيانات مقبس العميل بها. 


السطر 61 : بنية من نوع 5061300115 لوضع بيانات مقبس العميل -بعد 
الاتصال بالسيرفر- بها. 


السطر 62 : تعريف متغير سيحمل قيمة مقبس السيرفر. 
السطر 63 : تعريف متغير سيحمل قيمة مقبس العميل. 


السطر 64 : تعريف متغير سيحمل قيمة مقبس العميل الجديد من السيرفر 
بعد الاتصالك. 


السطر 65 : تعريف متغير سيحمل حجم البنية في السطر61. 
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مك7 


شفرةة اطلفئ 1//:1502/.21511 





نات , 

اعلمم بصمتمعض أنط 32: الأقعلناك ,غأدال] أعلمددن. 
عنذأأأكمة5 مومع 116112 لإمتلقع دهع الأماانره 
ما خاعدكمابت؟ فاعسا 


12 . 
:اكات 


ا الالكابع انمد تعانندأ؟ااعئ ععاوسجن] 
نزت عرعع ةعلاط متمدد 


دادع اده _كمصحوحمت _طامر ععاوجونر 
ا الالكاعد ع وانا عق | الالثا, 1 حاتت ات[نا_ ناناآرععمةغكص0 [طرممةعءقطن:مطوداةان ععاوسن] 
لاركعععمعططزبرع عماوين] 
ا م م 6 
ناض نافع اتدوة قط تاف فط بن مرق نرق طبضا ! !11ل :و5 ا "أنا, نالك نخاطءم خط عوسم عمءناوان] 
ود ا"ارار تمدع بدنالر 
حاتاات1 نا 1!11_ام بباح ح بروع 1ل 
مناطا اأكنام 
واناطا ممع 
نالشخلم_ الذاع1 رص تخطرممع1واناععى ععاوسبنر 
بتع امع انا تمده 
نالشاص_ع بساكم تخطارلمع1واناعءئى ععان بن 
بذج ع عب رعدرا مودس 
عا“إعداةاءان]آ اأدا 
عب عكاوهلت اأد- 
اع صقم تبات د زأةاءام1 لاىك 
مععكناءع بعد ااىء 
نالكاض |" الاوفت_لم باع ع بروع إزعواع, 
زدةءخنث إضام دس يسبروع بودن 
[ تلد وةءخناث إننام لعمسعبلح بودن 
ناع11ا_لاق -ح برع 11 
عل الاانت_لأارم- - بروع 1ل 
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نم إد] نا حر كا وكا [- للا للك 


ل11 


بر قم قم فم 
17 [- 


- كل ترا 


| وز[ زا 


حل كا 5لا [- للا كلظ لذأ مم 


ل إل[ يلل ايروكل يك يك فك وك فخ تب اي ام اا 


ذخ ذا 


مد 


,أت أناط "اللهم ! نط لخالخانت_لا ا طرمأسخطر ادع 1 ممعع1واناععى ععاوبىنر 
ع ]انان لأوع ملي 
اأععصصصدما_نا[ مهمع انط «لملفمدعئعدا ععاوسجونر 
دح بروع 11ل 
امع ادناددنا اأىه 
أععمصمص لامعاب الى 
عواع. 
أععصصمفت_نا1 لما نطلل النافب_لذا] رم“ خطءائزع | لمع [1وانااع5ه ععاوسونر 
أمع انععاءمكرباعاءموعهماء ععاوبن] 
أمعاالفاددتامنا الى 
9" لععععمصدعدانا ؛ أمعنا”ب» 110 اروم استصحاك ععاوبن] 
األوع. 
نالأاعد_اللاع1ا_لكارم- - بروع ززمواع. 
تعب رعكه الومعد لألى 
نالااع5د_جضع“طمع5_لزرم- - بروع [ززمواع, 
أمعناننه ا تمعد اأى 
األوع. 
أألوء. 
عأذدت ان باح ح بروع [زإزمواع. 
أعماءدد زنع لأاىه 
عاعدكم تمدع ااه 
بع برع كناو هداملا أأىك 
لارصاثتحاروداد نامع ععاوسجنر 
عواع. 
غذات اردع متودن 
اعم 
أألوء. 
علانا ,دع متورسم 
اعم 
جوع عمعءدوان] 


للا ملانا: دنال عوعظ وماشضدراك 
ادال 1 -,دال؟!1 8 5[ ناعذل"ا1[_طاركتنا_ ا خارواتناطرفضعوتدددع ]| “اوع] [1وانالمعد ععاوبهونر 
الالئاباالالئا, المالاتت اعذ_قارتنا_ [ كارو اناطرفعوتددع !“امع [1وانالمعد ععاوبونر 
بروع ععل 
ا الالكا, تدع اعكتظلاءت اعذك_ظطارطتتنا_ ا كارو اتناطرضعوتدددع | “اوع] [1وانالمعد ععاوسهوننر 
اعم 


207 


عل 


كم 70 [- اذك 


ان لبا لزيا لزيا لزيا ليآ 


ل 


خلر علر لمر حلر حير آنا كا لكا آلا آلا كا لكا كك لكا كا 1 5 1 ا ا 5 15 15 كط 5لا [- 
كا كك [- زن تنظ نا صخ يكز ؤي حير صا 5م  -3[‏ نن تلظ نا صغم إل زب حر كن 75 [- ا نان للك الا 


مك7 


ملموع وماشضدرات 


عوعرظ علماع د زاك ان[ 
12 “التق اقتع اعد _ا“نارط1_ اناعرواناطرفضعومددع !| “اووعع1واناتمعد ععاوسجونر 
نع أآباط اله ءدطرخمعاسك ععاوسجن] 
باعاقع ااعك انار ] طفص ناعرو اناطرضعوةددع | "ارمع [1وانالمعد ععاوسجونر 
نع اناا ولت 
اعم 
ممسوع علناعدزاذنان]1 


عو جاعصكم بتاع د زاك أن[ 
قعاةناةكاكا املق ,ث ,بمنارةاكفكن؟ ععاوجن] 
دح دبروع 11 
(".. .لغ د أاةاعلم] كاعمكصاتة 11 اروم استصحاك ععاوسن1 
عد[ت. 
("ناعءمكصابت؟ وم أاقاعاتمآ عمط 11 اروم استصحاك ععاوسنرز 
أأللاء. 
اعم 
مموع عاعمدكعم تعد اكات[ 


عوعظ أعياء دك اهزع 
أ ثنانات_نا1افضللة] - !ا رمبسرعواعاءدد 11. 
رع برع تاعناءمكراعاءموعهماء ععان بن 
أأللاء. 


آع:اناك_نا1 اضنكلم] حا أمع عع اعودد 11. 
أمعانععياءمكباعاءمععهماء ععان بن 

أأللاء. 

اعم 


اع انات_نا1 اضفكل] - !ا ععناءمخ امع ]اط 11. 
امع اندععياءمكباعاءمععهماء ععان؟ 1 
أأللاء. 
اعم 
مموع غعاعءددا برع 
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سم إ] ازيبا اكلر لكا 


33 


3 


مد 


عور ياأعدكم ]| تبامدع|) 
منامةع نفدم ععاوجنر 
اعم 

مموع كاعدكم نتددعا) 


< + ل ةي |“ | |[ |[ 0[ [ [ [ [ى[ |[ «[«[ | |« 838[|[ 3[ 3[ |[ 3[ |[ [|[ [ |[ [ |[ [ |[ | |[ [ |[ |[ | |[ |[ |[ |[ 0000010 ططظط<2صصإ: 
177أ71 أ 1 17 جا ا جا 1 عات ردات 1111 1 ا 1 1 
+09 | |[ [ز[ [ز[زذ 11 ططظط(<2صصإ: 


عوعظ رممرعكيادوم 
عاج نوعب عت لان اط نا ابتك التاجا زع ملعت تاروصصاسضدلم كاعد ععاوسن] 
بلحس زعب مدع رطم دودر 
(".. لع ءرقعك ومكاصصاط معد 11 [ناروه استصحاك ععاوسنا 
اعم 
ملموع عوعكادومم 
عوعظ رعرع كاوه امنا 
نوع سرع طبع طم | لان اط ناتك اجالع معت تاروصصاسضدلمنكاعد ععاوجن] 
(".لعممدغت ومتكاصصل] معد 110[ اروم استمحاك ععاوبن] 
اعم 
مموع رع ع كناود اونا 


عصط معاذا رع بعد 

2)]_نا | نصص] ,لاضع عه 5ك_ اتات راعل1_عام بأعناعده ععاوسنر 

بجح ع رع برع اما ند بوكر 

آع ا داناد_نا] اأشضللم]ح ع مبع وام اءود !11 
("اأعناعمد ععبيهد عط] عاقع تف أادمة ا" 110 اروص اسصطدك ععاوسنر 
اعم 

أألوء. 

(".. لعاقع تف أعاعمد رع روعت 1 اناروه انصحاك ععاوسبن 

آعلظ1_عاتل[ “الصةط_ملى عمعدء لل تياءدد ] تمده 

رم ربكصدغط ععانبتنر] 

4ت [عنمم_للى عمرع5كء لل تياءدد ]| تمده 

الذاشض_لاناناشل"!1,[ ءللت_دمك معدل لقاءدد ]| تمده 


عبرت لل ضناءمك أومعجاجكراع نعت ل لتناعمد اللعة ,ععبع داعاعءدت, لما ععاو برا 
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لأنعسعمع_اععرنك- - بروع آل 
ترك برع تاعناءومطراعاءموعهماء ععاوبجن] 


1107 
2ل 
3ل 
لم111 
ل 
11 
1 
113 
115 
15 
7 بال بال 
115 
13 
لاط 
لل 
11-2 
ل 
1-3 
1-5 
1-5 
7 ال 
1-5 
1-3 
لا 13 
ل ال 
015 
1133 
1-34 
0ل 
1-35 
1-37 
135 
133 
ناك 1 
1131 
ك1 


مك7 





("أعاعمدد ععسعد علا[! قماة مة "11 اروم استصحاك ععاوسن] 113 

اعم 14 

أألع. 14 

("..عمهنا وصافماط أعاعمك معد 110 اروم نماك ععاوسن] 146 

4ل 

امع ننات_ناعار اعم نانات_امبنت رعسم طخطرع سرع حاعناءمدطراععاعدع موف نكملا ععاوبونر 11 
43 

لخالكان ودف “كع سعكاعناءمكرمعأذنا ععاوسجنا 1510 


منسعسعمع_اععررند- - بروع آل 151 

ترك رع تاعناءمطراعاءمدوعهماء ععاوبن] 152 

("ع كنا ملكا ععمم عط فطتقم . ومتمعغكنا تمع" 110 [ اروم استمطاك ععاوسن] 153 
اعم 154 

أألع. 155 

(" أكدعناومعظ 10 أمعععم م[ لدع 110 اروم نماك ععاوبنا 156 

اعم 157 

مموع معدذذئل ع سهد 1523 

1 

اك طفع اتدومة كه اكات جات ع :مرق رخ نان 111 لاتودا“الب نال ناك ممشخط عصوصعظ عومطرمه بهد 2 150 
7 ماحهد_اناها -- ووانانا ]1. 1-1 

[معاات_ناع ددح رزووءدم| 11 122 

ععاصووع كا للقاءدد اأمعداى ,[زمع الللخععمموعع | عمدمه 123 

مقادموع ع لل ضناءدك لهاع سوعذاعناء مدت امعععة ععاوبن] 14 
معاءللقعامموع عه عللده 155 

بتجعباعماء وت امعط مده 15 

باع نانات_لابت لم خخطراعناعم امع انتطاععاعدع موف نمكم ععاوبنر 127 
عأذتن|.'_ناع ننس ناضعظ_نام 125 

ل" لعاععصصما ؛ معد 110[ ناروماسضماك ععاوبهن] 155 

ع8 ممدعذانا_نا1 لله ع أخالنات-_لذا! ترواناطر«ع [ ممعء[1واناععد ععاويور 1 
ناضعع_باءع دح روودءدسه| إزعواع. 11 

لات اكت أناط اهردق مضب بوععء ععاوبنز 172 

لاح مزهع 11 1 

بأمدع 1 “اللماذع]_مع تسعد اناطرواناط, دع ا ممعع[1واناععى ععاوبجونر 174 
أغزع 1 أومع جاع 15 

(" ؛ أصعاات 110 رامع ] «لالماعدع ددا ععاوبنر 1 

نع اناط “اععقمرائع | «لالمادءع ددا ععاو بن 17 

عمتااعلا ملم اع | «للمعدءع ندا ععاوسجنر 172 

بابع]_اع سعد ا ناعرو اتناطرضعومدددع !“امع [وانالمعد ععاوسجونر 173 

أبزع 1 للق -, باع 7[ع5_انابنبا 10 
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مد 


1 
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االلاء. 
عأدماك_باع -ح رودءدم| ززعواء. 
ل" لععععمممعهكان ؛ معسرعد ]1 [ اروم اغامحاك ععاوسن1 
أعناءمخامع ااتطراعاء مععهماء ععاوبن] 
األلاء. 

األلاء. 

قنرق طارنمةءك شاوه “انار كمتخطءع مكدع طم اعم عطنبملماسش لاقت ععاوسنا 

اعم 

موموع عمد نءعبتع5د 


عوعظ امع ]ننه ا لمعك 
عأ آلاط امع جاكئاع ا آلاط “الالهروداذدامز_معتسصعد_ ا ناطرواناط,ا “!ع 1[ ممعع[1واناععئ ععاوسجنر 
نات أناط امعهممعاننددا ععاوسن] 
راح بزوع 1ق 
ناث اطع لاط ملعمل ععناعمكططمع لاط |رفمعةه ععاوسهونر 
منسمع_إع نح ح بروع إلى 
ل" عامعاات عغط] طعت غكهما مداعععصمت" 11 ناروت اسدحطك ععاوسور 
اعم 
أألوء. 
انزع ] امعد اماع | الماع ]_دعنصعد_ ا ناعرو اناطراجدع | ممعع[واناععئى ععاوسونر 
9" : معد 110 ارائتع ] «لملقوعةع دا ععاوسن] 
عابط المقرائ:ع ] «لملقاعةءع دا ععاوسن] 
عمتاضعل"ا للم ع ١‏ «لملمق ودع ددا ععاوسن] 
باتع ااعك_ متت اشتع[1_دع تععد_ ا ناعارواناطرفضعوقكدع "المع [واناتمعد ععاوسنر 


انزع 1 “الت 1- 
اسع ااعدك_“اتترذا؟ا_ناع تطعد_ | ناعارواتناطرضعوتددع | “أوع]ئ[1وانالمعد ععاوسجونر 
ا الالةا,1- 
أأللء. 
اعم 


ملموع غمعزانات ] لمعك 
ا و جا جا ا باد با و و ا با وا وا وا و ب جا جا م وا جار واد وا وا وا وا كا او وا باد وا وار و وب د 
ا ا ا ا اا ا ل ل ا ا ل ك1 ا ا ا ا ا ا ا ا ا ا 
ا ا وو جا جا ا باد وا و و او باد وا با وا و ب جا جا ا وا بار ا وا و أو و و اب وا واد و ولو و وب 


عوعظ امم نادملنا 


1131 
1-22 
12 
153 
11535 
525 
1-27 
1155 
1-53 
131 
1531 
ل 
13 
1534 
1-5 
35م 
1537 
155 
1339 
لالات 
1لات 
لات 
الات 
لات 
كلات 
ذلات 
لات 
2 لات 
الات 
الات 
لت 
لات 
ل 
لت 
لات 
كلت 
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عص عط امع ا لفطك _اتتحارامة تاروصم استتموم]تحاعد ععاوسن] 
بتع امع اا بع عطم| تمده 
(".. عط فقعغد ومكاصملا أمع[ا-» 1112 اروماسضتمطد ععاوسنر 
اعم 
مموع غمع ]ا ماددم 





عوط امع ]جاده تاملا 
امع امع طم ارات اننا لتك الخدت امع الامروصصاضدلمتحاعد ععاوبىنر 
و" لعممدغد ومتاصمك عامع[ا» 110[ اروم نماك ععاوسنرز 
اعم 

مموع غمع]اتجاددتامنا 


عوعظ عأععمومصطمعات 
مجرم_مرمععع] ,الإفععرة_تاحهى راعلة1_عم بأعاءمه ععان بتو 
بتجع رامع اعا-و5 ودر 


1ع اناد_نا1 اضنئل"1- - عمع ]ا ععاءدد 11 
("أعناعمد أمعلات عط[] ععقع تف أمة" )11 ا اروم اغمحاك ععاوسن1 
اعم 

أأللاء. 


9" لعاقع نت عأعاعدد أمعنت" 11 ا اروم اغتمحاد ععاوسنا 

آعل!_عاتشمل اتمةط؟_ماك عمع ]ابل لتياءدد] مده 

رمع بكصدغط ععانبنر] 

نت[ عندم_ماك امع ]ادل لتياءدد ]| تمده 

1 ملت للة_عغعم) ععاوسن1 

تدع[ ءللة_ماك أمع ا لتتاعمدد | مده 

أمع نات ملك كناعدد اصع جام عمع اد ممضاعدت مقرل عغمع ا ععناعمد [إأععمممعء ععاوسونر 

ممصدع_ اعون 5- د بروع إلى 
("ععسعد عدا د[] عأععغصصصت د[ عاطخملا 111 اروماسمطد ععاوسونر 
اعم 

أألوء. 


باع انك_“ا تارامع التطرامع انتطعاعمكاععاعدعم بوم فك/نا ععاوبنر 
عأذنتنا!ة_ناعا عن ناشع م_ناعا عقت [_اطل الئانت_ناط 
اعم 
مموع عععصمفنغمعا 
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]1 
- وت ترا 


ذا 
سس 


بك يذل يكل يكل يكل يكل يكل يكل يكل يكل يكل وخر وخر وخر وخر وس 
لبا الما لما لما لما نط لما لما لما طلم كر اطلر ‏ لطر شلر 
نم .| با حير كا و15 [- للا كلظ لآ صخ وإ يا حر 


يكل يخ يذ[ ل 
حلر احلر 
كا كا 


اكير 
طم 
1-- 


مد 


رف عات د _اتصرةك هال أ"]ت فرط بن ررقت ضام ! [11ناتوة "انار نال فلات ممشخط عوعظ عممطعمع نات 
[عناند_أنابت؟ حت ووا“آنا 11. 
اع لالنات_باع دح ورةمرقص| 11 
و" تععععصصمم ؛ أمعلاكت" 11 !اروم اسضصطدك ععاوسوننر 
ناضعهع_ناع دع زووروموم| إزعواع. 
لات [ كنع لاط الالقرنوة مت طشضاربععم ععاوبن] 
راح بزوع 11. 
باعتع 1 الوق امع 1 _اللاعلات_ اناعرواتناطرائتع | موعع [1وانباععئى ععاوسونر 
أبزع | أوعملو 
(" ؛ ممعت 10 تارامع 1 #لملمادع ندا ععاوسونر 
نع لاط اق ع 1 مراع ددا ععاوسن] 
عمتاسعل"ا لم «ع 1 #لملمأادع ذا ععاوسن] 
ب ابع|]_الئاع1ا_اناعرواناطرضعودددع !“امومع 1وانالمعد ععاوسجنر 
امع 1 لوه ا -, افع ززعو_انابنرا 
أألوء. 
عدنك”ت_باء ع رزووءودم| إزعواء. 
(" لععععمممعوانا معد عدا 1[ اروم اغمحاك ععاوسونر 
أمعناعهاعمكاعاءدععهجماء ععاوبجن] 
األوء. 
األوء. 
ةنق دا تمت ةنا اضاروة “انار لمخخطقع ع كع طم اعم رطضم لمث اااقت ععاوسجنر 
اعم 
ممورع عمعطغمعا 


عوعط عدوت ا لمعت 
نع اناط أمعداكأك لاط الالقردات!"]_ الذاع1ال_ اناطرواتناطرائ«ع [ ممعع[1واناععئى ععاوسجونر 
نك اباط قمع اءندا ععاوسجن] 
لاد مزدع 11 
نات اكع انط ململ عغمع عع اعمد |,ضمعه ععاوبجنر 
ممسعسمع_اععرند- - بروع إل 
(" عمعسعد عط[ طعات؟ أكصا مم عاععصوده 11 اروم اغتمحاك ععاوسبن] 
اعم 
االلاء. 
اندع 1[ أمع جاكرائع | الم اندع 1 _اللأعلات_ اناطرواناطن«ع | ممعع[1واناععئى ععاوسجونر 
 "(‏ عمعات" )#1 راذع 1 «لالهادع ندا ععاوسجونر 
نع لاط “ماهر انع 1 «لمالهادع ندا ععاوبجنا 
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مك7 


عمتاسضعل" للم :ع | «لملمادع ندا ععاو بر 235 

كتداعك “ترا جع 1 _اللأع[ات_ ا ناعرواناطيعضعوتدددع ا “اوع] [1وانالمعد ععاوسونر 2310 
اننع 1 الات 1- 231 

باتع[ اعك_ “ا ترات" الناع1[ا_ ا ناعرو اناطيضعوقددع !"المع [وانالمعد ععاوسهنر ا 
االالاا,1- 0 

أأللاع. 24 

اعم ا 


ممدع ععدرعكه | لمعت 236 
أرتغاد لدعت "تخ 


- شرح شمرة البرنامج 





السطور 18 - 28 : في حدث تهيئة نافذة الحوار .. نقوم بالحصول علي 
مقبض النافذة ومقبض أداتي 41//1/0/-0175//7) و 1/0//ا//_ 5271/2 .. ومن ثم 
نستدعي الإجراء 5018131126115 والذي سيقوم بعمل بعض الخطوات الأولية. 
ثم نستدعي الإجراء ,7/6ع110015 والذي سيقوم بإلقاء خطاف علي النافذة 
0/ااراب!ا_جع/ 52 . 


ثم نقوم بتحميل وتهيئة مكتبة الوينسوك باستدعاءكاء150 آلالاع11111311<2. 


ومن ثم نقوم بوضع مقبس السيرفر في حالة استماع لأي طلبات اتصال 
قادمة باستدعاء تاعغ15 اا عنازع5. 


السطور 45-33 : شفرة زر الاتصال وقطع الاتصال .. وفيها نختبر نص الزر 
لمعرفة الوضع الحالي هل هو اتصال ام لا ؟ .. فإذا كان الزر به "اتصال" نقوم 
بإلقاء خطاف علي نافذة1171//7_/11////2) باستدعاء 200126116116 . 


ثم نقوم باستدعاء أ©61161186011116© لتجربة الاتصال مع السيرفر .. ولا نغير نص 
الزر إلي "قطع الاتصال" إلا إذا رد علينا السيرفر بالموافقة علي الاتصال. 

وإذا كان نص الزر "قطع الاتصال".. فنقوم بتغيير نص الزر إلي "اتصال" ومن ثم 
نقوم بغلق مقبس العميل بدالة غأع10565061»©. 

ثم نلغي خطاف الرسائل علي نافذة العميل باستدعاء ‏ 76ع0001»011لا .. 
ونظهر رسالة للمستخدم انه تم قطع الاتصالك. 


السطر 47 : نقوم باستدعاء “ع/ا#/ 56107056 لإرسال ما يكتبه العميل إلى 
السيرفر. 


السطر 49 : نقوم باستدعاء 56107100:116:15 لإرسال كل ما يكتبه السيرفر 
إلي العميل. 
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السطور 56-52 : عند إنهاء النافذة نقوم باستدعاء 5115061668 لغلق جميع 
المقابس .. وأيضا نقوم باستدعاء >©ا32506[لالا1»28© لمسح الوينسوك.. ومن 


انضًا الفعك :فك الخظاف تعن كلا من الستيرقر :والعميل: 


المتظوى 332365 فغراة كلها وقنانة تفرد الععانا فى قانية. :51186 
خية يتم تقرين غتوان لض الغراك إطوارة ل 01156 ي. ومن تمر إضافية:. ومن 
المفيد ان نقوم بتغيير شرير التمرير الراسي اوتوماتيكيا بعمل تحديد علي 
الغتضر ال خير دانها فى العانهة + كلها كان هناك دحال كور 


السطور 79-73 : شفرة إجراء 121813112116 .. وفيه نقوم فقط بإظهار عنوان 
الانترنت 15 ورقم المنفذ في صندوقي النص علي النافذة الرئيسية .. حيث 
بتمم استخدام أرقام داخلية عير مسموح لها بالتعديل من المس تو . منعاأ 
للخطأ عند التجربة .. ومن الممكن أن تتيح أنت عمل هذا التعديل. 


السطور 89-81 : شفرة إجراء تهيئة مكتبة الوينسوك .. وقمنا باستدعاء 


الدالة مد6:هخ585لالا وتمرير القيمة 2 لتحميل 2.0 175001//ا .. ومؤشر للبنية 
18 والتي ستستقبل معلومات عن المكتبة المهيئة. 


السطور 105-91 : شفرة إجراء 51506168 وبه نختبر كل مقبس إذا كان 
له قيمة فنقوم بإغلاقة. 


السطور 110-107 : شفرة إجراء ©ا©1150لالا:61©623© وفيه نقوم باستدعاء 
الدالة مناصقةء5861لالا فقط. 


السطور 126-116 : نقوم بإلقاء خطاف علي نافذة54///_/71////1/2 والتي 
اتفقنا علي انها ستستقبل احدات ورسائل المقبض .. وكذلك فك الخطاف 
عندما نريد ذلك. 

السطر 128 : بداية شفرة وضع المقبس في حالة استماع. 

السطر 129 : نقوم بإنشاء مقبس علي بروتكول2) | . 

السطور 136 -139 : نقوم بملء بنية 5061300116 هي أإع/ماع5060100015 


حيث نمرر عائلة العنوان 51ل!81_1.. تم نقوم بتحويل رقم المنفذ إلي صيفغة 
الشبكة باستخدام دالة 005]١آ‏ ..والقيمة المعادة في حجم ل00/لا. 


كذلك يمكن تمرير عنوان الانترنت الخاص بك .. ولكن يمكن تمرير القيمة 
/الالث_ 11180108 لجعل الوينسوك تختار العنوان بدلا منك .. ونفس الحال إذا 
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مورت القيونة ضفن إلى زقهر المتفة :: ,سشتكفل: الوسواة تكتان رقمر ميفة 
عشوائي لك في الحدود بين 1024 و 5000. 


السطر 140 : نقوم باستدعاء الدالة 100[ لربط المقبس إع/معك5اع!506 
بالبنية إع/ثتاع 506140015 . 


السطر 148 : نقوم باستدعاء دالة غأ58/5!/756|60//ا لدمج رسائل المقبس 
مع رسائل نافذة (اآلال/الالا_+اع/اماع5.. وتحديد رسائل المقبس بالثابت 
121 500_"/الا.. وتمرير الحدث الذي نريد مراقبته وهو 2)0221_(ا2 .. وهوه 
حدث خاص بوجود طلب اتصال قادم للموافقة عليه. 


النتظر 356 رفوم يوضع المقون:قئ نخالة استتماء: 


السطور 160 - 189 : شفرة إجراء النافذة 8/8 /الالا_8ع/5281 التي قمنا بالقاء 
خطاف: علتفا كل ما تريدة من إعراء: النافذة هوتدئء واحذ.:: :وهو إذا كانت 
هناك رسائل للمقبس 11_506©167/لا .. ومن ثم نقوم بتحليل تلك الرسائل. 


حيث توجد عدة أحداث للمقبس منها : 


حدث 0_800887 : حالة وجود طلب اتصال. 
حدث 20_©011/267 : في حالة إذا أتم الطرف الأخر الاتصال بنجاح. 

حدث مم2عغه_20 : في حالة إذا كانت هناك بيانات قادمة من الطرف الأخر. 
حدث 20_©61058 : في حالة إذا أغلق الطرف الأخر الاتصال. 


ومن هذه الأحداث نستطيع اتخاذ الخطوات اللازمة تبعا لكل حدث.. 


ففي حدث وحود طلب اتصال 80081_(]ا نقوم بالموافقة علي الاتصال بدالة 
أمع800 والتي تعود بمقبس جديد يربطنا مع الطرف الآخر .. ومن ثم بعد نجاح 
الاتصال نعيد مراقبة الأحداث الأخري للمقبس الجديد .. وتغيير زر الاتصال إلي 
"قطع الاتصال". 

وفي حدث وجود بيانات للقراءة 0_8580 من الطرف الأخر .. نقوم باستقبال 
تلك البيانات في مخزن .. ونتأكد من حجم تلك البيانات أنه أكبر من الصفر.. 
قبل عرضها علي المستخدم في صندوق المحادثة. 

وفي حدث إغلاق الاتصال من الطرف الأخر 0_©1058 نقوم بغلق المقبس 
الجديد الذي يربطنا مع الطرف الأخر ونظهر رسالة تفيد بغلق الاتصال. 
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السطور 210-191 : شفرة إحراء إرسال النص إلي العميل .. ونقوم به 
بإتيان النص المراد إرساله من العنصر 1_5211/2_1156 20 والتأكد من أن 
المستخدم قام بكتابة النص أولا ,. ثم نستخدم دالة 5670 لإرسال هذا النص 
ومن ثم نقوم أيضا بإضافة النض المرسل إلي نافذة المحادثة في السيرقفر. 


وشفرة العميل 01101 لا تختلف كثيرا عن شفرة المزوداء//©5 .. فقط في 
البنية 50616001011015 نقوم بتمرير عنوان الانترنت12 ورقم المنفذ للسيرفر. 


ونراقب أحداث 20_©61051 , ممعه_مع , آعغلالام6_مع 
ثم نستخدم دالة 0006© للاتصال بالسيرفر .. وعند قبول السايرفر الاتصال 


سيتم إرسالة لمقبس العميل للحدث561/ال20_©0(1 .. وباقي الأحداث لا 


في نهاية هذا الفصل .. إذا أردت معرفة المزيد عن برمجة الشبكات .. يمكنك الإطلاع 
علي مرحع 1:150©12لالا وستجده مرفق مع ملفات الكتاب. 
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221001011 01 
م 4 , 


البرمجة 3 مود الكيريل 


عل هااا أعمدع»ا 


أع ام و أع/اع0 اعناأزانا 


1. مقدمة 
2. كتابة دريفر 


سنتعلم في هذا الفصل كيفية كتابة دريفر لنظام التشغيل .. وفي البداية 
يجب معرفة الفرق بين البرمجة في مستوي المستخدم ع1100 ,عونلا 
والبرمجة في مستوي الكيرنل 11006 أعطاع» .. 

ملف الدريفر لا يتم ترحمته إلي [ع“©] بحيث يمكن الضغط عليه وتشغيله .. 
بل يتم ترحمته الي ملف بامتداد [5لإا5] .. وهذا الملف له بنية الملف التنفيذي 
غ8 التي درسناها من قبل .. ولكن لتشغيله يجب تحميله في النظام كدريفر. 


وسنتعرف علي كيفية تحميله في النظام في الجزء الثاني من هذا الفصل .. 


الدريفر يعمل دائما في مستوي الكيرنل 11006 اع0]ع؟! يطلق عليه [0 159أكا] 
بعكس البرامج والتي تعمل في وضع المستخدم 11006 /عؤ5لا او [3 10خ ]. 


وبالوصول إلي مستوي الكيرنل .. فيعطي للدريفر امتيازات وصلاحيات عديدة 
حيث يمكتك فغل ما تريد لانه لن تكوت هناك أي قيؤد من النظام .. 





فقط عندما يحدث خطأ أثناء عمل الدريفر فإن النظام لن يعطي رسالة الخطأ 
- المحببة الآن - والتي تفيد أن التطبيق )١/3006.©*©(‏ واجهته مشكلة ويجب 
غلقه , بل سيعطي الشاشة الزرقاء مباشرة (إ850 او 05 معع50 عناا8 
2630 .. والتي تحدث دائما نتيجة لسوء معالجة الأخطاء واصطيادها في 
الذويفرات: 


02005" سروت رتتيرك سر برراساء نيرت رتاه 25م لراساسي 5 عرا- عمس مياه تناه 25م إزت الإفاسوه» " 
رت "رسف وكاس سه 


حرت ‏ للعسة نهدت - تت زوين كن 2ك |[الكس توس يزه عحتح قاحس حزه عضر خيرتت 2 رت إل نزكواه 237 

اك عا ال سا شن تفريم ا د م 

عاد ت باوكا كاد ورين حيرت -2) حريت رز" 

- خيوف ذه لوركتفر كل رفت ركس سير 6 تر 

مره دست تارك 

عت سكي ا بانلوتك سيره 02 ختراح كسكد _ررك حرا يريم بنكتمر زرا حترركت حداعن ركس بستاوك 


وكا سه ررك عن حرا سيردت وظ حواح هرم وكاسكم داج ورك مم الا ستو ركام - جر حوروف رسا 
لمحتا سرررء من السك جتسو ع عة: حصرز»اءار اس زرا وراد 


لا عر عت ال ال ترا يا ترا ترك نكي رك ت دا جره 7ت]اكي يسررا»سه حزرت الدزكواده رسا 
ل سه ورك ورك ور كرعس 5د وإرعاقككت حرس سك ترس تان حمية 7 ازفاح يد خلراع سيركت باد 
مرا كتير 7 حجر تر اسة ننه تت رد ايع وزع تبركس نكر سس تامسن تررحت تحة سعر عتتاي سيار رسا 
ركلورف كيرا 5ك مسر : د لسير ست اعتس]اى 00د ست لكت سس 327 جخكيرك رتس !1ه رركت ولس 
تسن خرواكت #عست لحن 


حك اسع اي : لحف مقاورعت 
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واستعد لمواجهة هذه الشاشة كتيرا في الموضوع الحالي .. كذلك يجب 
التذكير بأن دوال مكتبات المستخدم مثتل 301/3032, 32ا6106©!, 5632لا لا 
يمكن استخدمها في وضع الكيرنل بالطريقة المباشرة التي وام .. ويمكن 
الاستعاضة عنها بدوال 4821م ع3]17ل8 التي يستخدمها [لظ! 5005لا ك 
6315© 7اعأكلا5 .. والمغلفة في ملفي 1.67<©6 7105111 ,7011.011 وهي مقسمة 


وأول شيء قد تحتاجه لكتابة الدريفر .. هو تحميل ال 2016 أو ممم 
ألكا أماع17م0اع/اع0ا من موقع مايكروسوفت : 


ات 1ع0015/001/0 70/0 0501.011 11121. انالا لاا/ / :مادا 


قم بتحميل [010(1] 581 2003 ]عل/ااع5 000115 1/ا/ا]) بحجم 230 ميجا .. في 
ملف 150 .. تم قم بحرقة علي اسطوانة او استخدم (ان |ا3ل]ألاب3الاللا 
لقرائته وتثبيته .. وقد يستغرق التثبيت بعض الوقت تبعا للخيارات التي تثبتها. 


المهم أن ال 001 توفر المعلومات الخاصة بويندوز ١7‏ وبنيات المعلومات 
الخاصة بالدريفات بالإضافة إلي المكتبات وملف المساعدة 4 
210 الخاص بتطوير الدريفات والذي سيفيدك بنسبة 900100. 


ال 12164 ليست كل شيء .. لإنه توحد حزمة )ا مالال»ا اختصارا إلي : 
61 1مطة لم86 الكملا 101 لكا عع/اأانا عل10|-اعممع»>ا 


وهي حزمة لمبرمجحي /1851 1 بها جميع الملفات الضرورية والمحدتة والمعدلة 
لتساعد في تطوير الدريفرات تحت 511 (مكتبات 1315طآا ا وملفات 
تضمينات 1125 126110 وماكروز 113105 وغيرها) واللازمة لكتابة الدريفرات. 


قام بإعداد هذه الحزمة الفريق الروسي 2-]نام] وستجد الحزمة مرفقة مع 
ملقات الكتاب: ولكن يمكتك تجمليها من الرايط الثالي والذى يحفوى أنضا على 
دروس مكملة مهمة لهذا الموضوع : 


10> | /0111». 7351132]. ع أأكطع/لل// :مخاطا 


من أهم ملفات تلك الحزمة التالي : 
اال .أالأم < طزاءطزا.االأم - عواءاالمام -1 
عاع.امكاومام < [ذذا.امكادومام - عصاءامكاومام -2 
2001.16 -3 
.لكام -4 
5105.6 -5 
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البرمجة في الكيرنل 
حيث أوك عنصران هما لمكتبتي دوال 881 0/300/6. 


ثالث عنصر [071001.172] يعرف الثوابت والبنيات والدوال الخاصة بالنظامامصالالا 
والتي تستخدم من قبل الدريفرات. 


رابع عنصر [05.170ا]1513] يعرف به ثوابت الحالات 5ل]568 وأنواعها. 
حامس عنصر [51115705.736] وهو ملف به ماكروز مفيدة جدا في التعامل مع 


النصوص في صورة يونيكود .. سنقوم باستخدام بعض تلك الماكروز.. وذلك لأن 


الكيرنل لا يتعامل مع النصوص إلا في صيغة اليونيكود. 





الآن بعد تضمين الملفات السابقة في المشروع .. يأتي لدينا هيكل الدريفر .. 
حيث يمكننا تقسيم الدريفر إلي 3 إجراءات رئيسية تدعي روتينات: 
لااأمعااع/ااانا -1 
01/0 -2 
011 -3 
ويوجد روتينات اخري ولكننا لن نستعرضها في الموضوع الحالي 
** أول روتين لأمع:0]16 .. وهو نقطة بداية الدريفر غمزه50 مع كما في 
لالأداعاااما في مكتبات اانا .. ويمكنك تسميه الإجراء كما تريد .. وله 
التعريف التالي : 


08[01_اع/الآكخاراط : اعع0/7/ع//(/0 ©0م لأ مازع انا 
1 | 10_55[ الام : 17 جنبر5/220/5لا/ 
عزع 0065 ع600 الاملار 


5لا 752 أع] 
م0 باإلاأمطاءع/ انا 
لأ معارع/ نا لمع 





1 - غ+©6ع[0,ع نام : 


وهو مؤشر إلي بنية 0811/58_08[527 .. يمكنك النظر لمحتويات تلك البنية 
في الملف [6ط0011أم] .. 


ناكا 5 21_0861351/ 011 


ا 0//اك 1/0 _ 
ما 0//اك ع512_ 
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افمك8 





110 0/ام أ06ع[06م0/اع0] 

110 0/الاما 05 

110 0/ام 5ع انا 

ا 0/ل/انا |٠512‏ انا 

؛ 110 0/ام عع | انا 

2 110 0/ام 0 دطع طاع/ | انا 

<> 11/0 2_5 0ن1االا عمق لاازع/ اانا 


0110/اط عم635ت]جراع 3103لا 
110 0/ام 010 
110 0/ام أأمطاناع/ نا 


110 0/ام 5310اع/ نا 
110 0/ام 1030 ناناءء/7 انا 


(2)مناك (1 + 1101[1عااناع_1811/101ا_11ا_ه1) 110/ام 1301م 





دنالاع 080[501_خ1 011/1 


قهذة النتنة توضخ خضائض كائن الذريفن: أهمرظلك الغتاضر المههة :لنا الأنى : 


أ1602[©6©1/١26‏ : مؤشر إلي بنية 08[801_طن1/اغ0ا تحوي جميع 
كائنات الديفيسز التي يقوم لدريفر بإنشائها ..نظام التشغيل يمثل ال 
5ععا/اء بال 5أع0[6 مئأل/ا06 سواء كانت لأجهزة مادية .. أو دريفرات 
برامج.. ويعمل كائن الديفيس علي معالجة رسائل 0 لهذا 


111615131 : عنوان بداية الدريفر لإاأمعااعننا. 


!ع1 : بنية نوعها 6ل0_511511ا10/الا معرفة داخل 
الملف [©21061!.15] .. لتحمل اسم الدريفر .. وطول الاسم 


35 ]: مؤشر بنية 10105_51110/6/الا تحمل 
مسار مفتاح بيانات الهاردوير في الريجستري. 


1030:لا:ع011 : يحدد نقطة البداية لروتين نهاية الدريفر .. ونقوم 
هنا بتحديد عنوان روتين لدينا خاص عند إنهاء الدريفر01030لا!ع7أنا. 


03 : مصفوفة تتحدد عناصرها من خلال القيمة 
التابتة [1101/الا؟ا_الا/1]2_11[_8111 .. وهي تحدد عنوان 


الروتين الذي سيعالج رسائل الدريفر وهو هنا سيكون عنوان الروتين 
31 نا. 
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ايدة 


2 - اخأج15]139/2 0ع 51دنام : 

وهو مؤشر إلي نص يونيكود به مسار مفتاح التسجيل لاع! 501519 الخاص 
بالدريفر المحمل .. حيث يمكن استخدام هذا المفتاح في الحصول علي 
بيانات أخري للدريفر.. وسنتناول جزئية مفتاح التسجيل هذه في الجزء الثاني 
من هذا الفصل. 


في نهاية الروتين نقوم بإرجاع قيمة تعبر عن حالة التنفيذ (نجاح ام فشل) 
تمحد فيمثايته نقوقر با رساعفا فمثلا إذا أردتا نات تجاء عملية تعميل 
الدريفر نقوم بإرجاع القيمة : 

55 ن)نلاد_5لا1 518 اع 


0 لالع 55عن)نلاد_5لا1 518 


تستطيع معرفة جميع الحالات وأنواعها من الملف [5.10لأ8أكا0] .. 


وكما كان هو الحال أثناء كتابة مكتبة اا .. فإننا إذا قمنا بإعادة قيمة تبين 
خطا في تنفيذ الدريفر فسيتم إلغاء تحميل الدريفر. 


ويهخد أربع أنواغ:هن الرسائل المدي لقيموهم موضحين كالاتى : 


[مععععععع3 - مع عملم ١7_25 ١‏ 
[معععععععم - م40000000] علمم + 7100م اجمغع1_10لم 
[معععععععق - م80000000] عرلم7 . 16 امنا 1لا 
[معععععععع - م620000000] علم ىج 8مجمع_1لم 


الدالة غمتءوصوطم 


توحد عدة دوال خاصة بالتنقيح منها هذه الدالة .. وهي دالة آم ماتلا 
تستخدم لإرسال رسائل من الدريفر بحيث يمكن استعراضها من اي منقح 
دريفرات]ع0©00109(] يعمل حاليا علي النظام مثل المنقحثثاعا/اوناطع0] ل 311 
01 والذي ستجده مرفق مع ملفات الكتاب .. أو يمكنك تحميله من 
موقعه الرسمي : 

علاع. نالاع | /اوطم] /07نام». 35 لاع ] م أولاك. ع/٠ز|//‏ :متاح 
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تعريف تلك الدالة كالتالي : 
١ ١‏ :2/15 ,010 /الاما: 20/7/7131 25010 أماءطوطنا 


حيث المعامل الأول هو مؤشر لنص يمكن صياغته لإظهار قيم به .. وإذا 
كانت تتذاكر دالة !50لا فهي تشبه 0002106 ..حيث يمكن استخدام 
الرموز التالية لإقحام قيم في هذا النص : 

(9/017/2 3110 , كللام/9 رعللام/9 ,ر5أ9/0 |90 ,05 ,)9/0 ) 


المعامل الثاني اختياري ويستخدم كمعاملات تمرر للنص الذي يتم 


ويوجد ماكرو بأسم [9©180] يتم استخدامه كتعريف النصوص.. 
مثال : 


“اع,("لاا9- )2اقع 55ع66ا5 03060 | 1م17 1نا")160 50 ,أمءطوطما عامناما 


** ثاني روتين 01030لا]ع/7 !]نا .. ويتم تحديده يدويا .. ليتم تعيين روتين ينفذ 
في نهاية الدريفر .. وهذا الروتين له التعريف التالي : 


1_08[1]ع/اآكاراط : اع ع0/17/ء///لام ©>10م 030ادناءع/ انا 
عزع 5م00 ع00© الاملار 


أع] 
0 30ماصناءع/7 نا 





المعامل الوحيد لهذا الروتين هو مؤشر للبنية 01ع[08_ا/011ا وهو نفس 
المؤشر الخاص بالروتين لإاأماعااع٠أانا.‏ 


وسنقوم الآن بتطبيق مثال بسيط علي الخطوات السابقة .. نقوم بتشغيل 
برنامج 1530/85١/‏ .. ونختار غأ2]0(60 /ثاع/ظ .. ونختار نوع المشروع )ألا واسم 


المشروع هو [اع٠أ]نالإالا‏ ]| . 
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اغمدة 


عمدلا غ6 عميزا - لعدع للا أععزمممر 





بك اطارمدددم 


!١1كدا‎ ١ د‎ 


عم | اععزممع 

زلادع.) ترحرث وردنا ) حرحرف عتصاباا ) 
كبرة أ عزنا له حرحرت عادكدد 0 

أقط ععاقم ممع 22 أععزدمط اانا 
أععزصرع بعد 

أععزصط 118ل 

اععزصعم عولن مام م 

كعم صدا حرحرم تتتصابا 0 

حرحرت ودنا] 0 


عط حرس 
تع ع زم مط أممكة اما أمعش ددم :ل :كلام داع عزمم 


ونقوم باستكمال خطوات إنشاء هذا المشروع .. ومن تم يظهر لدينا الملف 
[ لااكث. ع7 ]نالإالا] نضع به الشفرة التالية : 





06. 
الجعل 5 ,13 اع1100. 
©5011 ماع35 نامأأم0 


.كلكا طاكا 2 نثااع0نااع م١2‏ 3مكقطاتىء علناعما 
لمكا 2 نتااعل0ناع م١2‏ 3مكقسصساتى» علناعما 
علطا امطكادم اط كا 2نثااعل0ناءعصم١32مكقطاتنء»‏ علناعما 


17 ع100 لاك 2 اا 2 نثااع0نااع م١2‏ 3مكقطصساتنء» علناعما 
0[ امكاكمغام ىلا2 /ثااط ١‏ 32سمسكقسكء طناعلباعما 
3010515105136 32طاوةطا : عل0ناأعما 


.3 


ع00)». 
3 3 3 1 1 3 +3 +3 34 34 3 34 34 3 +3 34 34 3 37 34 34 34 +3 37 34 34 3 37 34 34 34 37 32 34 34 34 17 37 , 
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ديك 


08151 _اع /الخاراط نامع زط0اع/ انام ©6لام لإأمعطارع/ نا 
1 | 5_عما 10 لاط : قط / داوع ]كلام 
2/0110 نع 0ع /اعرام أنع0| 





أ0ع([106ع/ نام ,لاقع /املا 

1 غع[08_لاع/ اانا 211 :ياوع ع0الا355 
00ننااع/ !انا أع015 ,030النااع/ اما [لاجع ] /املما 
5:9 ©11لا355 


(”0ع030 | أع7غ1 ")50180 أماءطوطما عامناما 


0055 0)0اد5_5لا1 5148 أع] 
0 بإاأ مازع نا 
7 4 1 3 1 3 1 3 34 1 3 3 +3 37 34 17 34 1 34 1 4 3 3 34 37 34 1 34 17 34 7 3 7 7 4 7# 4 7 23 , 
0811 اع /الاراط ناعع [ط20ع/اانام ©>20م 030اصناءع/“ نا 
(”0ع030ادصنا ع7 نا")120 50 بأماءطوما عكامناما 
أع] 
0 30ماصناءع/7 نا 





لأ معارع/أزنا لمع 


ولا أعتقد أن الشفرة السابقة بحاجة إلي تفسير .. فقط قم بترجحمتها من 
قائمة |13 واختر 5556701 وسيتم إنشاء ملف أ06[©6 .. ومن نفس 
القائمة اختر الأمر »امنا لإنشاء ملف الدريفر [5لا0]61.5لإ1"!].. 


قم بتشغيل برنامج /ا©0601/1 الآن .. واضبط خصائصه علي الشكل التالي : 






لان الفط ا ير ااا 
ماعط “عتلامووص كلصلامنب ‏ - 259000 أزلع عارع 
ابابا ند تتماما ع الاامة ا ني د ص 













“اا أعمعع | ع رامخ ا ني ١‏ 
أنام الات أعمع | عكعدحاءع” عانادومع ني 
تأوناصغا] -جودمع ني 


ع اما قاأمعمع ع الاامة ا ني 





أدد وصا 
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فقط حتي الآن ستحتاج لتحميل الدريفر يدويا عن طريق برنامج مثل 05 
!030 أو :170113030 وهو مرفق مع ملفات الكتاب .. ولكن يمكنك تحميله 
لمع . عأ 0 05 . نانانانانالا// :مخاطا 


قم بتشغيل 0306| ]05 واضغط 8101/56 لإتيان مسار ملف الدريفر 
[5لاد.اع/ ٠‏ 0الإالا] .. 


15 2 احإناع ا رحيرار! راطف # 


بعصا معد يدعم عمعاعبو 5 مصعملا 
59 عااباك ذاناا عابيدة 5لا 
تلاتلا لكا أورعطمت 

لالاطط-ك59 [تناط] :ع 

3لاطط-5ك5 [3لاط] :مدع 


2007 ,5 أمع5 - لا.ثا :تعبا 


عمل ناساما لعا بماذاوع م 


فعسمم8 | اأخمم يلمع ناك مم مهنب ا اكعوصلناع 5 فحة عاصعم عدن :نا لاك رعمارنا 


ترما رعمارن] 


تعار8 وطن 2ك مانا 
4:34:35 | تالالاك 19 يعطممعامع 5 ,بلط علطا [ عالط عاونا 


1 عمابرع 5 
تع قمر 1 8 1 مناتر جا ترا بعللا 


:ل أعناداجا دنا تمعمعنا 


أت 51 551 ا 


#وطللاع 5 رعذ الصلكم»ا 


ايا "م :نات عحضةاعص| عاباقاع نا 
م 5-3999 


ععابسع 5 مداد ععاجرع 5 أرماك | أععاسع 5 عاعاوع صلا أعدامع د بعأاداومظ 





بعد تحديد مسار الدريفر .. قم بالضغط علي زر ©ا/ااع5 /ع]015ع] ومن تم 
اضغط علي زر 561/166 513 .. ومن تم قم بالضغط علي ع6/ااع5 (5]0. 
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الدريفر. 2 لنعيد 


اك 00 
ماق “#عطلاصووص: كصدااصت عغلطمفة أللع عاط 


57 الغ 2 | 348 + قه 42 | لله ها ها 


2211 صتاطكن[ 11-2 1 
1-3 عدت 1111 لالنانانانانانانا. لا 





*» ثالث روتين /!©اع]3م0]110/6]/015 .. وهو يقوم بمعالجة طلبات و1885 أو 
أع231 أ5ع1ا0ع1ا ألاملا0/ألام10 .. حيث يعمل هذا الروتين علي معالجة 
طلبات أكواد الدوال الرئيسية 6006 موناءصنط 113(06 12 .. وهذه الطلبات لها 
ثوابت تكون علي هذا الشكل [““ا_[11128_11] حيث يمكن للدريفر حينها 
معرفة العملية التي يجب تنفيذها.. 


كل طلب 0656© 1/0 له بنية تمتله هيه [ظ]1] والتي تحدد العناصر 
والخصائص العامة للتحكم في طلب الإدخال والإخراج 182 .. بداخل تلك البنية 
توحد بنية أخري مهمة هي البنية (10_518061160687101 والتي نحصل 
علي مؤشر لها عن طريق استدعاء الدالة 05186110631100 الأناع!الاناءع100 
وتمرير مؤشر البنية الحالية لها .. وبمجرد الحصول علي هذا المؤشر نستطيع 
معرفة المزيد عن الطلب وتنفيذ العملية المناسبة كما سنري فيما بعد.. 


البنيتان [1152] و[10_518016_100811011] معرفتان في الملف 
[ع21001.10] وتحتويان علي الاتي : 


أكواد الدوال الرئيسية والثانوية 0065© 00آ06ن؟ مطامط لمق “مزقم عط 1 . 
توابيع 5اعغ]531306 مخصصة لتلك الأكواد تحتوي علي بيانات الطلب. 
مؤشر الي كائن الديفيس 006686 061/16 للدريف. 

بعض المؤشرات والخصائص والرايات الأخري. 
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مجه ف كبرل 
والمهم أن الطلبات 5أ01065© يمكن تقسميها لتلاث مجموعات كالتالي : 
1 - طلبات قياسية 2010515 513110310 


وهي طلبات رئيسية113(01 .. مثل الطلبات التالية : 
امع _(الا_ما] 
رمامع_(الا_م خا[ 
غ11كاللا_زالا_طجا[ 
ا010ي)_طن1لاعما_زالا_ميا[ 
غ105ن11[1_0_طا[ 
طلالالمعان_[(الا_ط خا[ 


مثلا الطلب الأول 12_11[_65828718 يتم إخطار الدريفر أن كائن جديد ‏ هزع 
أ0[66 مقبض له .. وذلك عندما تقوم تطبيقات ال 11006 /ع5لا باستدعاء دالة 
مثل 16ا3]6ع61 أو عندما تقوم تطبيقات ١1006‏ |6076| باستدعاء دالة مثل 
| أتاعغ3ع21/1 .. ومن الطبيعي أن يكون الرد علي هذا الطلب ب 
5 )0لاذ_05ا1 518 في خانة [5لاأ105.5]3أ118.10513] ومن ثم استدعاء 
الدالة أ5علا0ع1اع 10017011 لكي نشير أن الطلب قد اكتمل معالجته لدينا .. 
ومن ثم إرجاع حالة الطلب. 
ع[امع1[_65ا_مم]1 ج ماوع 60 
غ111_6105_ه18 ع م لالامع13[_61ا_مم1 جه وعالمودءوه61 
ع511/لا_[ا_مم] ج عع ]ملالا 
ممعج_راا_مم] ج عاعالجعه 
110 0)_غن1/اغرا_زالا_ط18 < 1000م /اع0] 


2 - طلبات المبرمج المعرفة 5أدعنانع 160أقع2 111 تارق رومزم 


ويتم إشعار الدريفر بها عندما يقوم تطبيق ,52لا أو |6176| باستدعاء الدالة 
١1000111:0ع‏ اع لتمرير 10011 او كود تحكم 1/0 مخصص .. لكي يطلب من 
دريفر محدد ان يدعم هذا الطلب. 


والطلب الرئيسي للطلبات المعرفة هوا122_©010170/ا102_111_02 .. 
ويمكنك معرفة المزيد عن هذا النوع من الطلبات بالرجوع إلي توثيق الكادانا. 


يوجد ماكرو بأسم 11_©001© معرف داخل الملف "1.106 010أنلا" هذا الماكرو 
قوف ستخديد قزمة 32:نت :يها عذة من الخضائض لهذا النوع فى الظلبات: 
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وهذه القيمة تحتوي علي العناصر التالية : 
( ود5ع866 , 500مع11 , (وتأع نظ , عملا آاعءا/اع0 ) عما11_.0 0 


1[ 2ك 54 5 10987 1211 13 14 5ا 15 13517 19 لات إن ضن نت نت نت ناك 27 قت نت لاف أف 





١ 
العم انوع‎ 9 1 11 
قعميا مللعدصديع 0 0 ممت قع امن‎ 1 


) عملإ1اع1ب/اع0] 


بحدةدنوة: الذتقيسن. الذف تستتةر اعطاته كوة التحكهر الخاض. :10611 وتمحة 
العديد من الديفيسز مثل : 


للاعتا 


لا0ظا_ران)_عان1لاعارا_عا1طا 
؟ا15آنا_عن1لاعارا_ع 1ط 

لاع | 5لاد_عا1!ط_عن1لاعارا_ع لالط 
0/4161 5لاعكا_عان1/اارا_عا1]ا 
غ5لا10ا!_عان1لاعارا_ع 11م 

ا 0/الا | علاا_عن1لاعارا_ع الا 

اع ا لا1اط_عان1/اعارا_ع 1ط 

ال لاما )5_عن1لاعارا_ع 11م 
لاااعكاند_عان1لاعارا_ع الا 

لا/ل/1ا 10 >الاانا_عن1لاعرا_ع لطا 


وفي أغلب الأوقات سنختار القيمة الأخيرة[(//01/>الانا_10/اعغ2_0ا1© . 
ويتم تخزين تلك القيم في 16 بت العليا 010/لا ©0001 01 00/لا طون 


والقيم [0-32767] محجوزة لمايكروسوفت. 


ط) نا 


وهو قيمة مخصصة تحدد دالة معينة يتم تنفيذها في الدريفر ويتم تخزينه في 
0 بتات مما يسمخح بتخزين اكواد للمدي 0-4005 .. القيم من [0-204/7] 
محجوزة لمايكروسوفت.. وما بعد ذلك نستغله للقيام بالعمليات الخاصة بنا. 


©>) 19/06 11311511 01 لاع لق 


يحدد كيف سيقوم النظام بتمرير البيانات بين المستخدملم عن طريق الدالة 
0110١‏ )0/110 وبين الدريفر .. ويوجد أريع توابت يعملو علي تحديد كيفية 


النقل وهم : 
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٠‏ لال اع طالاظ_(1 10 لالز 


يقوم بتحديد طريقة 1/0 0ع1ع]آلا .. وهي تستخدم لنقل البيانات الصغيرة 
نسبيا .. وفي هذه الطريقة يقوم ال 12 بتحديد مؤشر إلي المخزن اع)آلا8 


المستخدم وهو ٠.‏ 
اانا ماع و/ا5.م01 ]11/550613 
حيث يستخدم هذا المخزن لكلا من عمليتي الإدخال والإخراج.. ويتم تحديد 
طول البيانات المدخلة في بنية[10(11 12801210041 10_5 من : 
ع ااع] آنا أنام 01101.10 10ععا/اع(ا. كإعاع 2330 موتأجع10كاع512م1]8.1 
ويتم تحديد طول البيانات الخارجة في بنية[10_5128012_100-811017 من: 
ع ااء] آنا انام 01101.01 10ععا/اع(ا. كإعأع 2330 موتأجع10كاءع512م1]8.1 


٠‏ 012)1_ل12_1ا0ل اعالز 
ء 0112501_آلا101(_0 طلز 


كلا الطريقتين [لا111,0 .. تستخدمان لنقل البيانات الكبيرة .. وإذا حددت 1 
فسيقوم (16210)01110/ا©0| بتمرير البيانات الي الدريفر .. وإذا حددت [لا0) 
فسيقوم (16100011110/ا©0| باستقبال البيانات من الدريفر .. وكلا الطريقتين 
يحدد ال 18 بهما مؤشر إلي المخزن المستخدم: 


اانا ماع و/ا5.م011 ]11/550613 


فسواء إدخال أو إخراج .. يقوم النظام بغلق منطقة الذاكرة الخاصة بالمخزن 
'اعآلا8 في الذاكرة .. ويقوم بعمل |(ا/ا لها او أ5لا ]مأم11عد5ع0ا لازأمطاع .. 
والتي تحدد بيانات تلك الذاكرة المقفلة .. ويعطي مؤشر لتلك الذاكرة في 
العنصر 71012001655 : 

5 00 1 
ومن ثم يقوم الدريفر بالوصول لتلك الذاكرة والتعامل معها سواء للقراءة او 
للكتابة عن طريق المؤشر 101/20055".. وبعد الإنتهاء يقوم بإعادة فتح 
الذاكرة المغلقة للمستخدم مرة اخري. 


٠‏ 111421 لا_م0 معام 
وبها لا يتم توفير أي /6]]لا8 6/0أو5ل/ا5 أو 0111 .. بل يستخدم ال 12 ذاكرة 


المستخدم الافتراضية للإدخال والإخراج اللتان تم الإعلان عنهما في دالة 
0010 )10عع/اع0]. 
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افمك8 





حيث للإدخال يستخدم العنصر التالي في البنية[/1 180121008110 10_5 : 


وللإخراج يستخدم العنصر التالي في البنية180 : 


]آلا انام 1/031 .0101 10ع16/اع0|. كأ ع 2330 موتأجع10كاءع5128م1]8.1 


اء]الناظاء5لا.م1 


ل) ووع©©2 
وهي راية تحدد طريقة الوصول أو الصلاحية المسموح بها .. وهم3 صلاحيات 


5 7لالم_غ ا[ : طلب حرية الوصولك. 
5 لمعه_غ اآء : طلب إذن القراءة. 
5 2115/لا_غااع : طلب إذن الكتابة. 


3 - طلبات غير معرفة ك5أدع نانع 41760ء10نا 


وهي طلبات لا يتم معالجتها ونقوم باستكمالها عن طريق إرجاع الحالة 
8112117120 01_11121لا_ؤلا1 518 للروتين. 


ونستعرض الآن شفرة الدريفر الجديدة .. حيث سنقوم بالتعديل علي 
المشروع السابق 761 0(1الا/! .. ليصبح كالتالي : 


ت., 
الدعل 5 ,خأقأآ اع ددن . 
3561110111 ١انالانزت‏ 


عاكلا كلا ق ص غاص تماع سن أ عدب اعطا عتم مخصلءع عدباحما 
عااكا, أل احص ها من أ عدب حصت عتم كعخصللرلةء عدبادما 

الا متك اص ص مامت أ عدب اعصاا عتم مخطللةءع عدبادما 
عاكلا مااع لاما عضن ماعب أ عدب عضا عتم خمقخصللةءع عدباحما 
ك1 78ت تخد أعقمماتك 3 لراعقصلا:نا عدبادما 

كازاء أحياحص ضياع شاط اع تمخخصلء دازام دادما 


و رورجم 
لا لالالالانا أعلدمنة عضن | _حا ماعنا 


تاك بلومح لخا لذ خال"اانا_عا_ااماعنا_ط الع 
لت لاراع تأعنا | [عالظا_ناناط | عام 
لا بارع دطعا_ا_اشر الذاكش_خا الع 


بع زم نا 


خلرى لا لا [- للا 


ا 


بم 
-آ1 


ادة 


بحالات -: اناا اصضيط بحلتكت عون | عدامعنا نتثا_اذاكم] عانانا.!_ | | ا 


زات ع :ووص دعام , <لات ع :إعصطخمام] 
الا (134 الاك زددعدعث)) خالا (ت1 الاك زعم | عع تعدا اضة د | [زع 
(لتدداغع“) خالا (2- الاد زحداء عصيط)» 


“لاع 
4 4 4 4 4 34 44 34 34 34 34 34 32 34 3 37 44 44 34 4 34 4 3 4 4 4 4 3 4 0 


151 لاا 


,اتات كارا لك ااانا ع اعنا_ع 1 ) عنات؟_ |1 ا باوع عوص)_تادام 
(ددحع لاث_لللذاتش_ح ا[ معنا [علذا_بان نم عام 
4 , عدم 3 لامع انتعدابا , ' عاصتمة ةط تعد نمدا" جالذال8 | 5_عانات !1 لكانا_باع ] لانن 
," 2اتزإتاق عط أمعع تع ناك دنا" تالالس | د _عنان )1 لكانا_ناع | اكرات 
,بعصم ق كاماد اامطصم نوكن 
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نا "عدم" أعصهععا عط[ ممع عمومعاعنتا طق داذاا_اصصع>»)_ 


عحح, 


82نف_اع ا[ طناط أععزطنايم متام حصئم كتمع صم اننا 


دالك811 | د_عانات 1 لئاط: طغخوصبؤواوع ديام 
كلا اث | 5 1 لكان كباأة ]5 اقدادا 
8[27نت_ع ناطناط عو زطن عد اعنام اتحما 
لطاع _لكانا] | شاالاجتا] الكانا_ا_ع_ا[أاعنا_ذلا | كر | ذ ,ذلااة 51 اودر 


عدم ة لكاعع تتتعنابا “املعة ,لا عع زط ترص“ نام ,عع تعبإفادع نام[ عجادثمنما 
أععزطناعع عنام ملعت ,عضاقع ,لا ابل كالكانا_ عا[ اعنا_عازع 
55 الاط_؟طنا شاط د ح جزهع [ز, 
,8م ةلكاتا تاك الصطصم ركبا العلعة كعاصناء اصطم بوكعادع رام[ عجادثنما 
عرلاد كاعد اتتعنانا عله 
55 الاط_؟طنا شاط - ح جزهع [ز, 
أععزحا نعم انام ,جتمع مجولم 
|اعزمتب _لع نبا [تانا أم: بهم عر راددت 
ب [لنالنام أمععام اع شع )_زاما_طن] إحدعصبيظطدزدكا زجع | جمدم 
عددا_أعاخت:_احاعاقدوانا أعداات 
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مم مم 
ند تت شا تت مهم 


م 


1 كل 


]م زنع يخ ذخ عن يش نش نن يخ نس 
ذذأ 


كا 


ذخا ذلا ذا 
كا 3[- قلا ا لظ لا مهعم 


نما ذا 


دن كنا إلا لبا كنا إلا 
حلر كا كلكا 3[- 


دنا ذلا 
لذن للك 


كل 
0-آ1 


افمك8 


* انك الكانات_ع ل ساعنا_زاما_طكا1 صصح عصبطءدزة “ا لمع | جمدم 
انحنم اداع أتموانا أعذا ات[ للا [ تماد أمععات) 
تتداصلايع نا تعداات تتداضاايع نا [ مع | نودم 
وتلأطاامة :زجع عررياددة 
5دع_ا_الاك_ذرا | ثم ]| ذ ,ذنااة 1ه مدر 
("تععقصا نعمانا" الاك 1 )5 ,غخصنردودانا عؤادمخما 
دوات , 
أعع زطناعع ا نعنام ,عع اتعناصاعاعنام] ععادثمنما 
ادك , 
الاك , 
لاه ,جع بور 
اعم 


ك1" 


م[ دز1م , | اعردت_ عا[ بأعناط: أعع زطاناعع عنام عمح عحصا أعاقع احاح ددزوانا 


11م ,جع ورور 

ل][_ أت: هع عرراددة 

55 الاك_كلا اث | 5 ركلاأة 51 كلاأة 1051 [جتمع | نودم 

نا ,ندا ل لد أت تبط تأكم 1 [جعتع ]| فدات 

وتلأاحاامن :هع عررياددة 

لاع اماع ل"ا]_نالكا_ نا[ ,حزرام ,أكععبوم هع أعامردوص لكادح] اادعادد] 
("أمعبوعع زعاتصة لعامع :]| ععدات انان" )ناث | ا بأصمهوطنا ععادمنما 
د5طع_ا_الراط_ذلا | ثم | ذ رقع منورنر 

اعم 


مدع عحدا نام ادع اداح د دزدانا] 


اعلنت_ع[ ب أعناط: أعع زطاناعع تتعنام [امع اجع جعويا تضاح أمط ضح احادطددروانا 


ل[ نان نم 1ل] 
كلا اث 5 | لكان در ةذه أقحاما 
انا لالانا: مما مط همه اتدما 


لا تأكنائز 

كع اع لزمدر 

نزام راجع زر 

1]_ لإأنةاكعم عن راددة 

أكع حنماغأقعص اتاءعخاكم 1 أصع ابا أاعجات[ 
تع ,المع نولم 


2354 





اك ثآا [- 3- [- 3[- 131 
نا كلظ لا م]غ] إ] لزنا كلم 


1[- 
ا 


1- 
1 كلا 


- 3[3- 3[- 
[- ذلا للا 


ذا 
نلا 


ادة 


ذات؟1 ا كانتا_ اام | 5_ن)] ملاعم عررباددة 


02_تاذام د ع ععص ]ام حص ات] أمطاحه تماعع معنا كع اموه ردص [ الع ] ١١‏ 
("عما_تاذا"'ا معباصعصه" )الاث | ام ,غمص طوطن عؤادمنما 
, تاذكاما_اعصعخا_ للعاعم عابط نعدنا. زاعع | ختصممع لماع مم ماحم ععادننما 
داذا"ا_اعفصصهم)_ أدمصعاد 
داكا"'ا_افصوصها_ أمععاه ,ممأ نطاعمعم نولم 
دع نطاع ب تأدلات 
131 د11 دا 3 د10 [زاعع ]| تزمدر 
دط5طع_ا_الاك_ذلرا | كر | ذ رذنااة 1ه مولز 
عداع , 
لاع | إكاع اح اناك"ا[_ | رالكل_طلرا | ك | د ,كنات 1ك انالا؟ 
تلظ , 


535 تأ5لانز 
535 5ل ]10513 [اعع ] تزمنر 


دع إطاع ا تأدلالز 
1111113 كلا 10513 [أعع | نزمنر 


١‏ لاع ماعط لكا1_نالم_نا] رباعم ,أمعروم مع اعامتصدص_لادح] اادعادة] 


متاتط امن :الع عررباددة 
وتلأططاغامة: اكع عروراددة 
لاك ,جع لمر 
آعم 

تزلتاكلت اص حص اداع دحروانا] 


[عزعنت_ عع[ فناط: اععزطتئعم نام عدناح اعحداصتتاك؟ اننا 
عاةل*ا| اع ااصطمم وكيا لالأعاعة عاك الصطم بجكعاعاعنام] ععادثنما 
أعع زطتارع نام ,بجع عنودلم 
أعع زطاناعع أنعنا. ([ مع ]| مزاع |[ اعزردف_اع”[انا) ,عع نعنإماعاصنام] ععادضنما 
("لععتصصنا تعبازنا" ناث | ا ,غخصترهوطنا عؤادثنما 
اعم 
حراعحاع لعحداصتاعب اننا 
بتلأصع رص مانا ددع 
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السطور 13-21 : قمت بنسخ تعريف الماكرو 00 )_اانه من الملف 
[1.170أ15106//ا] وتضمينه في شفرتنا مباشرة .. وإذا اردت حذف تلك السطور 
فقم بحذفها مع تضمين الملف : 

عأ اأع0 اننا ©0ن 0 لاا 


السطر 25 : التصريح عن كود له القيم التالية : 
220 - اللا 0ل>الاانا_غن10/اعغما_غالاآع 
900 ع وممتاعمنط 
3 ح جاع 11علظا_ما نل زع اما 
0 - 55غ2))م_/الاام_ 11 


3130/29/28 2726252423 2221201918171615 14131211109857] 6 5 4321 
000/11 





22 00 


وعند تخزين تلك القيم في أماكنها سيكون قيمة الكود النهائي هو : 
3 - 2237/7443 


وهو كود يمتل خصائص الطلب بالإضافة الي قيمة الدالة المخصصة. 
وهذا الكود نقوم بتعريفه في كلا البرنامجين!0306| اع7 اانا , ]اع/|]نالإالا .. 


السطرين 2/,28 : يتم استخدام الماكرو 1116 5_ع0ا120/الا_ماع 1 لاانا 0 
وهو من عمل -لا0 للإعلان عن متغير يحمل قيمة يونيكود .. هذا الماكرو 
ضمن ماكروز الملف [5]11705.1736] .. وإذا لم يتم استخدامه فستضطر 
لاستخدام الطريقة التقليدية : 


0 ا "كه رع" "1 ارا راع" "م" "1١‏ 1" يلل عمممولاععزناءمان 


حيث نقوم بعمل مصفوفة من ال 0:05//ا كل حرف له 2 بايت .. ويتم تخزين 
الحرف علي النا نت الأ وك هرف النائك النانى اقدمطة رفن 


أو يمكن استخدام دوال التعامل مع اليونيكود التالية : 
0ك 100 نا0 !1 انأ دادم كما 


10 1[ ل أدع1600 لال معمم 4ا 
0510 1[ ع1600 لال صمعمم 46اا 
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المهم أننا ا سنستخدم الماكرو 25_5758126آ112060/الا_1120ال01©© ويمكنك 
معرفة المزيد عنه بالقراءة قليلا داخل الملف [5111705.5136] 


السطر 32 : هي رسالة سيتم نقلها من الكيرنل إلي المستخدم. 


السطر 38 : تعريف متغير محلي من النوع ١151811005‏ وهذا النوع معرف 
داخل الملف [11065.10] .. وسيحمل هذا المتغير حالة التنفيذ. 


السطر 39 : تعريف متغير ليحمل مؤشر إلي كائن الديفيس الذي سيتم 
إنشائه. 


السطر 0 : وضع حالة التنفيذ في البداية إلي خطأ في إعداد ع6غ6ئ/اع0 1/0 
وبعد أن ينجح التنفيذ نقوم بتغيير تلك الحالة.. 


السطر 42 : نقوم باستدعاء دالةه ععالاع0اع]3ع10)1 .. وهذه الدالة تقوم 
بإانشاء ديفيس حديد ليتم التحكم به واستخدامه من قبل الدريفر .. في حالتنا 
هذه نقوم بإنشاء ديفيس وهمي.. 


15 
2ه 1 تنلات ص وه نات 1ل 
م عع وطاعع”7 1م11[ "1لا لظ 21011112 111 


, 511512 1 سعط ورظامج 1نم 1[ 11 114 

, مك11  228""1‏ عدس دامج دسماز تاا 5111 _كانانة) 1 انالا 11م 
ب تمبت لعج دم لز 111 1_نانا! اانا 111ل 

5125 تمع نطاجعدء وطاعج 1م11[ 11 111 
22211153172 نم5001 111 

عع وبتطائع”ج 1جوع1] * 1غاكالكال)_كلن) 1 لاماتاط "1لا 

1 


لاحظ الدالة تعود بقيمة تعبر عن حالة التنفيذن 81518105 .. ومعاملاتها 
كالتالي : 


٠ء‏ 1116:0266 : مؤشر لكائن بنية الدريفر الذي قمنا باستقباله في 
الروتين لإاأاعااع/ !انا .. 


٠ه‏ 17161151011512 ع1/ا06 : بيحدد عدد البايتات المحددة للدريفر 
والمخصصة لحجم بنية الديفيس الممتدة .. ونضعه بصفر. 
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ء ©31لاع16/ا26 : مؤشر إلي مخزن به نص يونيكود يحدد اسم كائن 
الديفيس .. وعندما يقوم المستخدم ١1006‏ /ع5لا بعمل أو5علا0ع5 1/0 
يقوم بتحديد الهدف الذي سيصل له هذا الطلب عن طريق هذا الاسم .. 


ويجب أن يكون هذا الاسم في المسار الكامل 898 ااناتا .. والمسار الكامل 
هنا هو مساره ضمن نطاق الكائنات .. حيث أي اسم ديفيس ١١‏ لدريفرات 
لامالا إزاع1100! زع“ااما 15001/5/الا] التي نقوم بكتابتها هنا .. وحتي لغيرها .. 
يجب أن يكون في الصيغة : 

ذم م ١10601‏ 
وذلك إذا أراد القيام بعمليات 5أ2©00©5 1/0 .. ومدير عمليات 1/0 يفسر حرف 
"١"‏ علي انه /631360566© 5560306 يستخدم لإقحام حروف خاصة .. مثل "00" 
في دالة 6أ5أع1/50 .. وبالتالي يجب إضافة "٠"‏ أخري ليفسر أننا نريد 
35اكا836. 


هء عهملا7عءزلاء2 : يحدد نوع الديفيس »1/102_700ا2112_08] .. ونستخدم 
هنا النوع 101//10)الانا_102/ا02_غاآع. 


٠ء‏ 113:316115115)ع1/ا2 : يحدد بيانات إضافية عن الديفيس .. لا 
نحتاج إليها حاليا ونضع قيمته صفر. 


ء علاْأولااعا5 : قيمة 8001630 تشير إلي جعل الديفيس خاص أم لا .. إذا 
كان خاص فلن يسمح سوي بمقبض واحد مفتوح لهذا الديفيس .. 
ومعظم الدريفرات تضع قيمته 3|156. 


ء 02[6©85ع16ل/ا2©6 : مؤشر إلي متغير يستقبل مؤشر لبنية الديفيس 
الجديد الذي تم إنشائه.. 


السطر 45 : عند نجاح الدالة ععال/اع0اع]3ع10)1 .. نقوم بإستدعاء الدالة 
| أا70|1الا5ع]31ع11 وهي دالة تعمل علي إنشاء وصلة رمزية بين اسم 
الوصول إلي كائثن الديفيس من الع1100 (ع5لا..وإرسال طلبات 1/0 له. 


15 
) 11121 ال نطستدت ناودع 2 ئات 1ل 
, 2111731812 121:1 1 و#طصسرد د ا 111 _كانآنة) 1 اانا 111 
تلعج د مانا تاا 5121 _كأنان :)1 انالا 11م 
/ 
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٠ء‏ ©1311 11111ا712011:ال5 : مؤشر إلي مخزن يحتوي علي النص يونيكود 
بمسار معين داخل المجلد الخاص ]١22[‏ أو [5ع6ال/اع100510] وهو نفس 
المجلد ولكن تم تحديث الاسم الثاني إلي الأول منذ ويندوز 87.. مع 
وضع إرتباط إليه. 

المجلد ]١7[‏ يحتوي علي جميع الارتباطات الخاصة بكائنات الديفيسز التي 

يستطيع المستخدم رؤيتها والتعامل معها ضمن بيئة]أ0 32. 


ء ©311لاعع1لاء2 : مؤشر إلي مخزن يحتوي علي النص يونيكود يشير إلي 
افتمر كائن الديفيس الذى ثم انثيانة. 


وعند نجاح الدالة تعود بالقيمة 0)55لا51/21105_5 

السطور 48-55 : نحصل علي مؤشر لبنية كائن الدريفر في المسجل “اع 
ونقوم بتثبيت روتينات خاصة لبعض الاكود 152 الرئيسية.. عن طريق العنصر 
130100 .. فاذا كنت تتذكر تعريف هذا العنصر كالتالي : 

(2)منال (1 + 11010 كااناعا_الااا/18111ا_زل/ا_ط1) آ0[1/اط ررهتاعصلط 30 


عبارة عن مصفوفة حدودها بحجمر 4بايت هو حجم النوع (1آ20/01 وعدد 
حدودها بعدد عناصر الاكواد الرئيسية +1 .. تلك الاكواد مرتبة متل التالي : 


0) - 05م : 0 لالع غ امع ل _زال/ا_مخا] 

4 - 05م : 1 لامع عغم[ط_راع الالملا_ع امع كلان_[/ا_م ]ا[ 

8 - 05م 2 لالع غ05 1ن)_[/_مخ]ا]1 
2 - 05م : 3 لالع رامع11[_8_ ]1 
166 - 


5 ( 4 لالع غ11ا//ا_[/ا_مخا] 
بالتالي للوصول إلي موضع الكود الرئيسي داخل المصفوفة .. قم بضرب حجم 
الحد بالاندكس. 


وعند الوصول إلي موضع الكود داخل المصفوفة .. يتم تخزين به مؤشر لروتين 
ال ؛015031]3617ا المناسب.. ونقوم بتغيير الحالة الي00555لاد_5لا1 148 5. 


السطر 59 : وإذا لم تنجح الدالة >اناناء1ا0ط7الا5ع]3ع10.1 نقوم بحذف كائن 
الديفيس الذي قمنا بإنشائه باستدعاء الدالة ععال/اع0اع]©|1010 وتمرير مؤشر 
الكائن إليها. 
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السطور 66-76 : شفرة الروتين 0(15031]61701631601056ا وفيه نقوم بمراقبة 
حالة الحصول علي مقبض فقط .. يمكنك إضافة الرسالة 01055 _[0_!1]ا1 
بنفسك لهذا الروتين .. وكما عرفنا من قبل فإن الروتين يستقبل معاملين 
ممرران إليه 0 


الأول 666[ 0عءع]1لا06م وهو مؤشر إلي بنية كائن الديفيس الذي يتعامل مع 
طلبات 1/0 القادمة من ال11006 ]عولا .. 


والثاني 01178 وهو مؤشر إلي بنية [21158] والتي سبق الحديث عنها والتي 
تحتوي علي معلومات الطلب 186. 


مع الوضع في الاعتبار أن : 
مه1_ جزم ععلعمبة مجمزم 


الاثنان واحد والبنية [188_] معرفة كما ذكرنا من قبل في الملف [001.106أم] 


ونقوم بإرحاع القيمة 51811/5_51/00555 لهذا الطلب في بنية 1188 .. وتمرير 
كائن م011 إلي الإجراء أ65/ا0ع1 1001770116 حيث هو عبارة عن (أأق6أ35] 
0 من الدالة أدعبالع1اعأع1م10)017 .. والتي تشير إلي انتهائنا من 
جميع العمليات التي نريد تنفيذها علي طلب ال 1/0 وبالتالي يعود طلب ال 
2 الي 303066 1/0 المسئولك عن تمرير تلك الطلبات بين الكيرنل 
والمستخدم. 
1 
1 1025نت نات 1ل 
ص1 2182 111 
778551 دعرج رعرع الق00 111 
1 


وتحتوي علي معاملين .. الأول وهو مؤشر البنية 2118 .. والثاني هو قيمة 
تحدد الاولولية للتنفيذ .. ونضع قيمتها !لاع /اع0_101لظا_10. 


نلاحظ استخدام الماكرو ||135163 من برمجة -]لا0آ الخاص بضبط معاملات 
دوال ال 881 علي بيئة 64 بت .. حيث لا يدعم ١1451!‏ طريقة |اة35]6] 
يمكنك قراءة المزيد عن هذا الموضوع فيءانانا 10001/5لالا. 


وإذا أردت دعم أ 32 فقط فاستغني عن طريقة ١(اق185]6‏ واستخدام الدالة 
الاساسية أدوعناو0ع8اع1ع1م10017. 
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السطور 78-115 : شفرة روتين (01503]000110ا .. والذي سيستقبل 
رسائل المبرمج المعرفة الخاصة .. 


في بدايتها نقوم بالحصول علي مؤشرين .. المؤشر الأول للبنية 112 ونضعه 
في ا5© .. المؤشر التاني للبنية [10_51801100-81101 ونضعه في ([0© .. 
ونحصل علي المؤشر التاني كما ذكرنا من قبل باستدعاء الدالة 
115361)0اع]لان)اأع100 وتمرير مؤشر البنية 0 الحالي لها 
وستعود بمؤشر موضع الاستاك للبنية الحالية. 


ثم نقارن الكود لدينا ©156_©00"! بقيمة الكود المرسل للديفيس .. وإذا 
تساوي فنقوم بنسخ المتغير [ :50|_ا©6/07كا_ ] إلي مخزن ذاكرة المستخدم 
اع]نا8زع5لا بواسطة دالة هدمع الاع/ح0 اما 


172011 
) عبت مسرع الع 21110 
,21213151311 معنا * 11ت لال 570110 111 
, م8معنتت5 * الاأكظااتا لش اظلا 1غ 151ل 111 
11 2113لا 1 _داله 51 112 
/ 


حيبت المعامل الأؤل.هو غتوات القدق ». .والمعامل الثاني هو عتوات المصدر .. 
والمعافل الثالث هو حجم البيانات العراد نسكها. 


ثم نقوم بإستكمال الطلب وإرساله إلي ال/ع113630! 1/0 . 


السطور 117-123 : شفرة روتين 051030لا/]ع7٠1(ا‏ .. وفيها عند إنهاء استخدام 
الدريفر نقوم بحذف رمز الاسم بتمريرة لدالة >اناناء760|1الإدعأعاع1010 وكذلك 
نقوم بحذف الديفيس بتمرير مؤشره إلي الدالةعءا/اع0اع]أع|ع100. 


ونتناول في الصفحة التالية كيفية كتابة برنامج مشغل للدريفر 1ه 
:030 . 
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تقوم الآن بإنشاء مشروغ 888 132لالا بأسم ٠03061[‏ :0(06] وله الشكل 


التالي : 


اك 


ع ااانا _ناكنا 1 اانا_11 10101 الع ااانا _نالظرنا ا _ 1001:81١1‏ 
]نا تحداملا امنا ددصا 
6005 _0للع1003:8111_5 


أتعباومع 8 لمع 5ك 





زر /]0(]17/6آا ١|030‏ : يستخدم لتحميل الدريفر. 
زر !0117/61 1030لا : يستخدم لإلغاء تحميل الدريفر. 


زر أ065ا0©] 5600 : يستخدم لإرسال طلب إلي الدريفر ومعرفة رد الدريفر 


القائمة 00ا : يتم عرض بها نتائج التنفيذ. 


شفرة الملف [/0306| 761 011ا] كالتالي : 
حاطل كتتدمعصامم صعباعتما 


عصاكتاعصهها ععبادحما 
عطاء ع3 دكب عاعباداما 
عضا 2ت اأعوصصصط؟ ععباحما 
عصا ع3 ااعطه ععباحما 
عاملل عتاحة معت ع دادما 
ال 3 لركقمم عاعباحاما 


دزا عت اأعمعوهها حاتاععباحما 
طلا عت زعكبا طاأافءباحاما 
دزا 32اأعصصص؟ طازامءباحما 
ازا 2ك اعمط حاتاعدباحما 
حلا عخامةماعة. دااع دادما 


سمخ يع نا لمر لا اكلا 3- للا للا 


مو قو مم مم 
جح برا نزم زن 
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ادة 


طلاء, 2 تساكقم دالاعتباعصا 14 

15 

111 كلأ أ ختخط عقسصستع3 محمقصللةع عتباعضا 15 

تلاكة ,5ط ع3 تمص عقصتك3 امقطللةع عدباعصا 17 

13 

ات رت نا |: , لات رت نالترا:, | :بلاط [11طإنابانا عد“اناوانا 19 
نا ؟انالاانا: (ا[إ نابم وصاستمطك ‏ لات 

34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 +3 34 34 34 34 34 34 +3 34 34 34 34 34 34 34 4 34 4 4 #4 زر 1ن 
لالننالاانا أعدعمنا عن [_عا_ا[تراعن] ‏ كت 

كات باصت كاتا لكك الذانا_ ع[ أعنا_عالآع ‏ 23 

3 لاناح ماعل | [علذا_بان عن 4س 


نا داوع د5طع_اائ_لزلكائض_ع لزع 5ت 

ملت -: تأدا مكنا معدلات دتعضه | ععانتعنا نللا_امل"ا نان ظل_ || ا "نت 

حززات ع-:ووعععم , <لات ع : إعص ادام 2 

عالا (13 الا5 زددعع-دثت)) خالا (15 _الاد زإعمن | عدانعنا) )امه م | ززع 28 
((تصطاع“]) خالا 2 الاك زصد ا عصبط)) 29 

[“انالذاع لات 

31 || # # 4 # 4 34 34 4 34 34 3+ 34 34 34 34 34 34 34 34 3+ 34 34 34 34 34 34 3+ 34 34 34 34 34 34 4 34 

اذا إلانا,. حك 

1 لامج 1الااش[لا_نانا[ 55 


1لالا1 لاع لعا 1[انا_ناشننا_اذا ا 8 4ت 
عنالا1 نايع لاطا [انا_باشداالكانا_لذا | 8 35 
تالا باقع اطعلالطظس_بالإاعد_لذاا 8 5د 


ل لامع جائلا_ [ كا 37 

"ااا لككالكانا_ ع[ ساعنا_عا1) نات _ ١|‏ ا نامع ع2 )_جاكام 35 
(ددعمانات_الللذات_ع 11 معن | [علخا_نانتن | عل الات 39 
3 34 34 34 24 34 34 34 34 34 34 34 34 34 34 34 4 44 44 34 34 34 34 244 34 34 34 34 34 34 34 34 34 34 4 4 2( إالك 
3أ23. 1ك 

لام" تبات لصم ناسواما” حاك عمردل"ا ك2 2 تك 

(لا] نباك ذكخ حاك طخقط” نك 2 تك 

زلا نباك كك حاك عباط كك 

(لا) نزباك كك حاك مزع اباط كك 

4 74 34 34 34 34 34 34 34 34 34 34 34 +3 34 34 34 +3 34 34 34 34 34 34 34 34 +3 34 34 34 34 34 4 4 34 د # 4م | تلك 
03137 7ك 

"ا" ععدةأعص[آط ‏ تك 

2 2 أقاط ‏ 3ك 
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افمك8 


"ا" أعودصد" كط لا5 
ك2 ععترمكط 2 51 
"ا" ععاستصناط ‏ 52 
اس" دع 8188م 53 


حو وشيم آلا 


السطر 142 : متغير سيحمل اسم الدريفر[ولا30©.5/!] المراد تحميله. 


السطر 143 : متغير سيحمل مسار الدريفر كاملا .. وفي المثال الحالي 
سيكوت التريفر بحانت ملف ال8«)68. 


السطر 50 : متغير سيحمل المقبض المعاد من الدالة)ع006750113030. 


السطر 51 : هتفير مسجمل الففعض. المعاذ من حرا استعخ دا قركالة 


عع المعكعاقع 0 أو دالة عءا/صعدمعم60. 


السطر 52 : متغير سيحمل مقبض الديفيس المعاد من جراء استخدام الدالة 
عالعاجعء 1ن . 


السطر 53 : متغير سيحمل عدد البايتات المعادة من رسالة الكيرنل. 


شفرة الملف [(اكث.!1ع030| 76 !]| كالتالي : 
نات 
اعاعصمم ختصصعص ألط 32 الأحعل ]5 ,خأقأآ اعددىى . 
عم إكرعه عدت 110118: 0[تالاق35] ١‏ اناا تنا 


2 


طلا تعاعتصا أعنناننا عوباحما 


عم , 


ذخا ذا صلم كا كا [- للا 


ا 


5111: 

10 

ا الالكارعاتصدتاعاباعد“ااصت عماحمنما 1 
ع ععاداةأكص[دا مودلم 1 


5ح حلص احص صصص ا لمر عواحثتما 14 
تارداص اوانا العاعق نا اتات _اف[نا_نانال, ععصةكص حار موةءوطزمعودادانا عجادثمنما 15 


ادة 


لارككععم رط يرع عيادثنما 15 

1 

34 34 +3 34 34 +3 34 34 34 +3 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 34 +3 34 34 4 34 34 4 4 4 # # م 130 
1 

رف رن ممت قعل أمنأرتي؟ خط ابا ررق ركنن 1 ك1[ لنا: ود ا« انام لضان مإطخباط عحتام عدءناوانا لات 
دا “لاقع مولز 21 

تنلات [1نا 1111 متاح د بجع ]| 5 

تانا_ | ارط تتحاردمع][وانااعت عيادننما 23 
63 أق اط لمكم 7 

لالكات |""امانا_امارتباح ديوع [إدوات, 2 

زممةءخناتت ]ام ومين مدع بععصسولم 2 

21+ مرةرودنابن [ام لعوع برلمع ععسولم 2 
11 )_لاع ح ح عزليم 11 8 

8ع“ 1ثانا_ناشفننا_ذا امح دجعوع 1 ا 

اع انا_اتصا أأدهء 30 
8ع“1تانا_ناخث_الاانا_لك 8ح دينهعم أإصواط, 31 
أعمانا_تدداضنا أأده 32 
[دعلايطظ_ناللاعد_لزاقمح دينوع إإدواص, 5 
أكعبامع و معد اأىهء 34 

الددزة , 5 

كوت 5 

عكن)_المأتاح ديعيهم أزدواة, 37 

اعم اانا_تدداضنا أأجء 38 

لارط احا وداداتنافصع ععادثنما 39 

عداع , الك 

كاذ ا نجع بولر 41 

آعم اد 

تلظ , 1 

علاما اردع مولن 44 

آعم كك 

دعدع عمءطوانا ضك 

4 


اطاحم 2م انا_اعقصا 3ك 
تاختطمتك ملاعملا فضط_عزت امل بتتحاطاعع أناغخمعمططت عيادسنما 4 
عممةل" انك لاعاعم طخخطمنك «اعاعفمأدع ندا ععادننما لا5 
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دية 


ددع _لاثت_اات_تاعداش لكات ز"«ا__اك ,لا ,لا , تعوحصةا“تكصهمت عجادبنما 
2, اعودصد "كط نولم 
انالا <-! بزهع ,١[‏ 
ب( "عاحزتضتعع 1١‏ | ا عومخقصةد"“«ا كط عع اسعكعاخصن عجادبنما 
بطع _لات_لاقض_ع لمعمل عامتودةع اك ١1خ[‏ ا 
أراظلت | ك_نالكات“اعنا_ ع[ تمعد شع[ نانا_ اعلذاصعنا_ ع[ نوعدت 
لا ,لا ,لا ,لا ,نا رط ختطمتك ااأعلمعت ,عدت لاتام_منطمع_عر ا[ رتمع5 
باتع رعع تعدا نوكم 
االالخ دا بزهع ١‏ 
الك ,نا رعع مكل عع همك رداك عواوبنما 
("مععتصا عملنا 11 1 ار وصاسشتصطك عؤادثنما 
عوات , 
امع دق اكعدا عيادثنما 
أ2 اباط العلعق, أ عغصاءمكمه عواوثنما 
لقع ل"لمهت 2 عوعم مز ١١‏ تععالدء زعع؟؟ عدعادع | ١1١‏ كز[ ا 
علاط 'العاعق وصمانتصطك عجادثبنما 
عوقصة “كط ,عاتصدلتاعع ا تصددومان) عجادبنما 
درط , 
دواع 
("تعالةع [ نعوتداة“«ا_اكدع نت ]| )1 ؟ | لم وماشخمطك عنادثنما 
ررك , 
اعم 
متضع عمنا_ددصا 


اطاحم عم نا_عخداصانا 
كلا امك _ عن[ تدعو وراد 51_عع رودم أتحادا 
ددع لاثت_ااق_تتاعاداش لكات" اك ,لا ,لا , تعوحصة1“«تكصعهمت عوادبنما 
تع أعوحصد"ا_اكا نوكم 
االالخ دا جزهع ١‏ 
ب( عنتمت 1١‏ انا إعودصدة "كط عع اب عكصعهمت عواوبنما 
د5طع_ا_اث_اات_ع_ا ]تعد 
باقع رعع تعدا نولم 
االالخ دا بزهع ١‏ 
نان ] 5_ انا | لكانات_ع را[ ممعم عع بتع كطا عع ترومداد صم عوادبنما 
كلا 51_عع عدم للح 
عع استعكط ,عع استعدماواعنا ععادبنما 
عع امكل ,عاتصدلاعع ا تصددوما) عجادبنما 





ع أي | 
ست 


ما 
ا 


كا 
حن 


لا 


ا كذ هذا 1 وكا 5ك ولا 
1 حم زيمن زرا كلرى لظا اكلا 3ه للا 


اذك 
1١ 1‏ 


؟! 5 ]| لذن ذا 


-[ -[1 -[3 -[1 


- للا اللا 


0 


ل- [- اللا لالظ للا 
نا 


ا 


نخس د 


نا لالظ اللا 
ظلرى كا 


دنا ذلا 
1 تا 3ه قلا 


نم 
حل 
0 


ادة 


ل" تمعخصاصنا معنا ١)‏ ؟ [ ار وصاشتمطك عؤادمنم] 59 

عوات, 3 

("مماادع زععتعدصعمت! | 11 | نارصصاشخصطك عواحمنم] 31 
اراك , شا 

عوات., 33 

("تعاأةع [ 302,1دادا"ا _ادصعمت | 511 | اروص اشخصطك عوادمنما 94 
دراك , 35 

اعم مه 

ددع عمزنا_عدداصلا 37 

5 


اطع أوعباوع ‏ تمدعك وت 
ددع _لاث_اات_تاعجاش لكات ز"«ا_ اك ,لا رلا , تعوحصة“]_كمعمت عجادثنما لانا1 
ع, اعوحصدا"ا طلا لولم 101 
االالكا <-! مرجع ,١[‏ 110 


ب(" عامتمتجع ١‏ ]| نا عوقصةد "كط ععلء؟ عدمعهمت عوادمنما 103 
دطع_ااثك_اات_ع_ا تاد 4 

لاقع رعد تعدا مولم 105 

االال) <-! برهع ١١‏ 1 

لم ناشعم_ 1 اعللاعادا, ل لامزصوت عع 111 1 ]| ار عاطعامصن عمادمما 17 
حال" | كلع _للاعتارراى لا تابرع | لازا مع نان 1 

لاب اشاتان الكا_ع | لا1 م | اش_ع لزع 10 

87 ,عع امنا متمدم 11 

عا_الاشثءئ_ع انالأاتلما_نا1 اشفل"ة] دا بنهع 1 111 

اباط عقر ناء, نا قدصم تاكاطار عدا تعنانارات صم ام [عع معنا عوادنم] 112 
لاركع ‏ بطاع م الاق دادع 113 

ب("عمة ؛ ماعصخبطمة مصاتيط ١١‏ كز | ارك عابط اللعلاعق غاص ءحكمر عمادمنما 114 
دع ]صاصم 115 

#ان)_ عل عع اباط “العاعق ”عابط العاعق, ا انالكائتمععودددمامن عوادمنم] 11 
مداع 11 

("تعانلدع [زعااععاحص١‏ ]11 | ارعصاشخمطك عوادمنم] 115 

املع , 113 

عع تعناط عاتصدناعدكدات عوادمنما نا1 

مداع 121 

("تعالدع زعدتعددعمنا ]| 11 | اروص اشتمطك عؤادمنما 1 

"وت 15 

عداد., 124 

("تعالةع [ أعودتداةا"ا _تاطصعمنا ]| 11 | اروصاشخمطك عوادضنما دار 
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افمك8 


[التدزظ , 
آعم 
متحت أجعروع معد 





بم 
الس 


-1 


حزم 


بم 
نلا 


ل انا لالانا: تادامك عصنك وصاشندحاك 
تا 1< تال" 1 5[ تعذل"ا]_طاى أف اط عودددع |« افمعد عيادثنما 
اال الكا, ا انالكاى | لكات | غط_طا, أفاط عودددع ]ا “«أدمعد ععادثنما 
تدع ععك 
| الالكار هم اعكططل لات اعذد_ظ ار أفاطعودددع “امعد عيادثنما 
آعم 

تزتحنعت وصاشتخصحاك 


بم 
ا 


بم 
ذم ذخا كذ كك با ليا 
اس 


زْ 
بم 


بم قم تم تم ايم 
ذم تنبا اتمعة ذبة ثب نآ 
نظ تنا صلم ضغ 5ت 3د تت 


بم بم 
١‏ 


531 لدرخ 


تحتوي الشفرة علي ثلاث إجراءات رئيسية : 


1 - 0300| 
2 - م107 0ا030)املنا 
3 - أدعلاومع01مع5 


أولا : إإحراء وع030:1ا 


السطر 49,50 : نحصل علي مسار كامل لملف الدريفر [5لإ5.]ع٠!](الإلا]‏ 
في المجلد الحالي .. ونتحفظه في المتغيرط]أ07/83. 


السطر 52 : نقوم باستدعاء الدالة /ع6501130306م0 .. وهي تقوم بعمل 
اتصال مع (مدير التحكم الخدمي) 1136306 |210م) من للاثاع5 علي جهاز 
محدد .. وتقوم بفتح قاعدة بيانات محددة علي هذا الجهاز.. ومدير التحكم 
الخدمي هو المسئول عن إنشاء الخدمة والاتصال بها. 


1132322 م ال[ افك 
+ 11211115113112 112015124 ا اخطه 1 
م 52103112 تطدعا دناس 1 21511طه ا اناه 1 ا_ 
عمسم م شقوعء 1م112 ماك انا 372 


١ 


للدالة 3 معاملات هم كالتالي : 
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31 


ع30اع1 1136م : معامل اختياري .. وهو مؤشر إلي نص يحمل اسم 
الجهاز المراد الاتصال به .. وإذا وضعت | الالا أو قمت بالتأشير لنص فارغ 
فسيتم الاتصال بمدير التحكم في الجهاز المحلي. 


3335/30 : معامل اختياري .. وهو مؤشر إلي نص يحمل اسم 
قاعدة بيانات مدير التحكم المراد الاتصال بها .. ويجب أن يكون قيمة هذا 
المعامل هي 5211/1025_86111/_087888515 .. بمعني أنه يجب أن 
يؤشر هذا المعامل إلي نص به " 7/6أ526ع1]0/اثاع5" .. وإذا كان قيمته 
االالا .. فسيتم فتح قاعدة البيانات ‏ 611/2_08617888515م2_وع12/امع5 
افتراضيا. 


ال يحدد تصر يح الوصول إلي تعد بيانات مدير التحكم 
660 لام 50_11 


وعند نجاح الدالة تعود بمقبض لقاعدة بيانات مدير التحكم الخدمي نقوم 
بتخزينه في المتغير 50011303061 .. بينما إذا فشلت فتعود بقيمة لالالا . 


وإذا 


أردت معرقة .ما هو الخطأ يمكتك حينها استدعاء دالة5]8/10قلاء6 والتي 


لا تأخذ أي معاملات .. فقط يتم استدعائها وتعود بقيمة الخطأ .. ومن ثم 
يمكن معرفة نوع الخطا من الجدول التالي : 


16201 00> 1 انااع] 
5 360655 لعأدع نامع ع[ رماع 1لاعرا_كد5غ460_لالطمع 
لعأمع0 


0363635 لعذأععم5 ع1 [#15اع_01لا_د5غ0را_ع 88/485 5018_0861 5ع 
.أ5ألاع مط 5وع00 


5 اعأع31320م ل0ع1أععم5 م اع اع“ 24ل2_نا1[اثم/الا1_طمطمع 
.3110/اطا 


السطر 55 : نقوم باستدعاء الدالة عنا/اثاع5ع3]6ع1) .. وهي تقوم بإنشاء 
كائن لخدمة وتقوم بإضافتة الي قاعدة بيانات مدير التحكم الخدمي. 


للذالة:135 معامل .. تستعرضوم سرها #التالى : 
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1 31:5255716 126 انا افك 
, 1ت 3 23 د لاط آل[ ائلفةا_ناد 


, 211312 21271 5ج 1 1-5112اظكآ 


, 7113112 3 1م52 12111 


ا سا اس 115 


م ددعع جم روجع ددعم نامرك لللناللالا 
ص ومبتاعج دمع مرك اللان الالا 


مع مجع وخ كمرك لل1نا اانا 
, [تجعرع دونع جععر مرك اناالا 


, تالطع وط بع مد د لم1 

, نانع جوع امراك واج 1 
عل .ات زعام 08 

,5ت دنع دوع و ناخ 1 

, 22د ادمع دعت و سرع ودج 1 


اتحدت مام ع ورج 1 


عم ساس 15 
ام سنا سف > 2115 
رسن اودكا 
ع سا اس > 25 
ام سنا سف > 215 
ازا حا اس > 1159 


1 - 5511303060 : مقبض لقاعدة بيانات مدير التحكم الخدمي والذي حصلنا 
عليه من جراء استدعاء الدالة :006205011306306 .. 


3-2 


©30لاعء1/اع5م! : مؤشر لأسم الخدمة المراد تثبيتها في قاعدة البيانات 


.. ومسموح لطول الاسم حتي 256 بايت. 


30ل الإام5أ0م| : معامل اختياري هو مؤشر إلي أسم يتم استخدامه 


في برامج 561لا لتحديد الخدمة. 


25 : يحدد تصريح الوصول للخدمة .. قم بإعطاء جميع 


التصريحات عن طريق القيمة8©66555_٠‏ الم_5281/1©2. 


عم/ا! ع16/ااع01/5 : يحدد نوع الخدمة .. وفيه نحدد الخاصية التالية : 


ععإنارعو مزع7٠‏ ]نا 


[0<»00000001] خاع/ا1[خارا_اء االخاع>ا_عن]1/اماع 5 
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ادة 


6 - عم/19 15ل : يحدد خيارات البداية للخدمة .. ومن الممكن أن يكون أن 


260 أمدء الم عنااج/ا 

عط لاط /إأاج31مامأناة 0م5130 عع اندعو م 1 0_5]لام_عن1/اماع5 

ماع كلاد 1150نا0 !3230م أمنأم0» عن أنازع5 2 »دت))) 
322 


ماعأولا5 عطا لإط 0م5632 مع7غ ل من ]باع م 001_517ه2_عن1/اماع5 
0 لإأمه 10ا3/ا ذأ عنااقن/ا دلط[آ .مع1030 00 دت))) 
د5ععألااع5 إع/ 01 


امأمم عن اأنااع5 عط لإم 0م5530 ععانرع5 م 2 1411 5_رالا4 لاع را_عن1/اماع5 
عط ذ5ااق© ود5ع06م 3 معانلا عوطقم 3 ت22))) 
٠‏ ]ل! ع©1ناثاع 513115 


0م5531 عط أمصصقه أمطا عع ا/برعو م ماع ا15488را_عن 1 ناماع 5 
ما االاوعء؛ ععاألاازع5 عط 530 مغ كام ممعم 4))) 
8160 8ع 1لالاع5_جممسوع م00 غزمعع علا 


عط لإط 0م53 ع7 021 من زأناع0 م( [51/4_الاع | 5لاك_عن1/اماع5 
5 عنااأقل/ا كلط !ا .اهلع انا 111 10111151/516 1دت))) 
.دععالااع5 ازع/ أل 6ه] لزامه 1100نت“ 


وسنختار القيمة 1|(_51/28171/امالاعغ]102_0/١528‏ لكي نقوم نحن بتشغيل 
الخدمة وتحميل الدريفر بدالة ع16/ثاع5]81]5. 


7 - 0001101 ]لال : يحدد درجة خطورة الخطأ في حالة إذا فشلت الخدمة 
في العمل .. ولا داعي لوضع درجة خطورة حتي لا تؤثر علي النظام ونعطي 
لها القيمة 216110151 0جاباع_عن1/اع 5. 


8 - 30ل[ ا1ط81031/2836م| : معامل اختياري ولكن في حالتنا هذه سيكون 
إحجباري.. وهو مؤشر إلي اسم يحمل مسار ملف البيناري للخدمة .. وهو هنا 
سيكون مسار ملف الدريفر [و5لا5. | 


9 - 0300100101050 ام| : معامل اختياري يحدد مؤشر إلي اسم يحمل اسم 


المجموعة التي تنتمي لها الخدمة .. وجميع المجموعات تجدها تحت مفتاح 
التسجيل التالي : 
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افمك8 


عع ع5 ومع نا | لاع | ولاكاع 14611 اث )0 |_لاع) نا 
00 0] 


تحت اسم 56ذا .. وسنضع لهذا المعامل القيمة ١‏ الالا لأن الخدمة لدينا لا 


0- 011/13010م! : معامل اختياري وهو مؤشر لمتغير يستقبل قيمة فريدة 
للخدمة في المجموعة المخصصة 11000ع030010ام| .. ولن نستخدم هذا 
المعامل ونضع قيمته ا الالاا. 


1 - 5ع600670م6م! : معامل اختياري وهو مؤشر إلي مصفوفة بها أسماء 
الخذفات الدخوف الى ني تنهياها قبل أند يرا الخدمة الخالة:فئ العمل 
لق لست ووه | الفسامل ونه فيمة ]الال 


2 - 30ل إقادعء/اثاع5م| : معامل اختياري وهو مؤشر إلي اسم الحساب 
علي النظام المراد للخدمة أن تعمل عليه .. نقوم بإعطاء هذا المعامل القيمة 
االالاا وستعمل الخدمة علي الحساب المحلي]انا0ع36 اع أولا063|5٠.‏ 

3 - 2835511/00م| : مؤشر إلي كلمة المرور لهذا الحساب.. وإذا أعطيت لهذا 
المعامل القيمة 1 الالاا .. فهذا يعني ان الحساب ليس له كلمة مرور .. او 
سيتم تشغيل الخدمة علي الحساب المحلي. 


بعد نجاح الدالة تعود بمقبض الخدمة التي تم إنشائها .. نقوم بتخزينه في 


المتغير ع2/ااع55 .. 


وإذا فشلت الدالة تعود بالقيمة لالالاا ومن المفيد معرفة قيمة الخطأ 
باستدعاء الدالة :6635800 .. وفي معظم الأوقات سيكون الخطأ هو : 


[1073-431] 1515ا2_عن 1 لاع 0115ماع 


والذي يفيد أن الخدمة موجودة من قبل بنفس الأسم في قاعدة البيانات. 


السطر 61 : نقوم باستدعاء الدالة عغال/اثاع5ا5]3 والتي تقوم بتشغيل 
الخدمة .. وللدالة 3 معاملات .. 
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ادة 


1 2 5123115-91 بانانا8 

,252127122 انالا القلا_عاد 1 

وم مج نلك ص امرك للناالانا 11 
تناع عا وطمعه 21 52ج 1 * 2115111طه نأطزت 12 __ 


1 - عءأ/معكط : مقبض الخدمة العائد من دالة عع المعكعماوع 0 أو 
51/1 ؟00. 


2 - 5وامع10/اثاع25النالاا/مال : يحدد عدد العناصر الموجودة في المعامل التالث. 


3 - 5امأ0عع/١10مم16/ااع5م|‏ : مؤشر إلي مصفوفة نصية تحتوي علي التوايع 
100115 المراد تمريرها للخدمة في بداية عملها. 


المعامل الثاني والتالث يستخدمان فقط للخدمات .. ولكن لخدمات الدريفرات 
لا يتم استخدام هذان المعاملان. 


وعند نجاح الدالة تعود بقيمة غير الصفر .. وتعود بالقيمة االالاا في حال 
فشلها.. ومن المفيد أن تستدعي الدالة:6©]135180 لمعرفة الخطأ. 


ثانيا : |احراء اع1103010118لا 


نقوم فيه بفتح مقبض لقاعدة بيانات مدير التحكم الخدمي .. ومن ثم نقوم 
باستدعاء الدالة 66٠/اثاع65م0‏ والتي تستخدم لفتح خدمة محددة والحصولك 


) 022256212 شال[ اللقة_ءاد 
,25112113323 ظا نا 51_11 12 __ 
, 251131312 1255271 12-1511212 12820 0 
تسم حص عع دمع نامك لللنااا10 12 __ 


للدالة 3 معاملات كالتالي : 
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1 - 550113030 : مقبض قاعدة بيانات مدير التحكم الخدمي. 
2 - عمنقالاعءا/مء5م! : مؤشر لأسم الخدمة المراد الحصول علي مقبضها. 
3 - 011/10512086055 : يحدد تصريح الوصول إلي الخدمة. 


وعند نجاح الدالة تعود بمقبض الخدمة .. واذا فشلت تعود بقيمة 1 الالاا ومن 
المفيد أيضا استدعاء دالة 1101 12أ135أ©06 لمعرفة الخطأ. 


السطر 85 : نقوم بإستدعاء الدالة ع1/16/ 201110156 والتي تستخدم لإرساك 
اكواد تحكم في الخدمة .. 


) 1115155-29216ني) بانانا8 
,255217122 ءال[ القة_ناد 1 _ 
, اجعع ندم مك للاا10 لم 
نا 3ع 2235 1255171 511115 128515121715 اناه 


للدالة 3 معاملات : 


1 - عءالااع65 : مقبض الخدمة المراد التحكم بها. 


2 - 0/0101 : قيمة تحدد نوع التحكم المراد القيام به .. من بعض تلك 


القيم التالي ' 
20 أمدء الم 00> 0١‏ هه 
ععألااع5 0ع5ئلا3م 3 5ه0111لىا غلال1 1011 1_0 0ظ 1 01 )_غعن1/ااع 5 
ع1] .عمالاوع؟ لالامط5 ١‏ أهطاا 3»))) 
علاقط أ5ناط عالصقط ع نبارءعكم 
عا 


غ111 ل01)_غع د5نامط_عى1/الاع5 
أطو ووع36020 


ا أقطا عمأنارع5 3 0115لا غ250081 1501_1101 010ن_عن1/ااع5 
أمع!الاء 5أاا أاممعء؟ لانلامطهك 4))) 
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ادة 


عط مغ ده6غ3 طم 10لا 5لاأ3ا5 
32301 أمنأمم» عن أنازع5 
أدلامط ع1ل0طقط عء/بلمعكظ عط[ 


خا أشطخا ععا/نرعو 3 د5ه1 0لا غ5لا4ط_01 010/1 )_غن1/ااطع5 
ععءإبنامءع55 ع١!‏ .عكنا3م لالامطهك 2 »ت))) 
عط عناقط أكبامص عالصهطا 
11100 ان _ع كنامط_عنى1 /اماع5 
مط ووع36060 


خا أشطخا ععا/رعو 3 د5هم1 ملم 00 ->-_01 010/1 )_غن[1/ااطع5 
ععإبنامزع75/ علطا .مم5 لانامطهك 1))) 
عط عناقط أكناص ع1الصهطا 
.أطوك ودوع366 102 5_عن1/اماع5 
مم5 عط ووالمع؟ عم 
لاملا ربعءألااع5 3 10 أدعنامع! 
ماع06 لمعه غ00 لالامطك 
.ععانااعو عط مغ وامخاممء 


ويستخدم الكود 5707-_-521/1605_©01171901 في إرسال كود إيقاف للخدمة 


3 - 5لاأهأ5ع7/16اع05! : مؤشر إلي بنية 5511/105_512811/5 تستقبل بيانات 
اخر حالة للخدمة. 


عند نجاخ الذالة ثهؤد نقيمة غير الضفر .. وعدن فقشدلوا :تعؤة بالقيمف ا نالة: 


السطر 87 : يتم استدعاء الدالة عءأ/مءوع]»0616 لحذف الخدمة من قاعدة 
البيانات .. 


1 5551ل 1016 بانانا8 


قلآلاققة_ 56 م1 


المعافلن الفحيد للدالة قو همقتض الخدمة .. وزعوة رقيمة قير الصفر فيد 
نجاحها وإلا ستعود بالقيمة ا الالا. 
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السطر 88 : نقوم باستدعاء الدالةه ©13001اءم1/ثزع210565) والتي تستخدم 
لغلق مقبض الخدمة وكذلك مقبض مدير التحكم الخدمي .. ويمكنك 
استخدامها لغلق كلا المقبضين في نهاية الإجراء . 


) 2113123012 1555551 21لا 1 از بانافاظ 
عه رجطت 25 اال االفقظ_ 52 12 __ 


وعند نجاح الدالة تعود بقيمة غير الصفر وإلا ستعود بالقيمقاالالاا. 
تالنا : إحراء أدوعن 56110180 


نقوم فيه بفتح مقبض لقاعدة بيانات مدير التحكم الخدمي .. ومن ثم نقوم 
باستدعاء الدالة ع7/16اع615م06 للحصول علي مقبض الخدمة .. تم نستدعي 
الدالة عا اع]3ع1) .. والتي تستخدم لإنشاء او فتح ملف .. او فتحع16/ا06] 1/0 
.. وتعود الدالة بمقبض يمكن استخدامه للوصول الي الديفيس وتبادل البيانات 
معةه. 


) 25222111 )ا طلا نا لق[ 


, 121115210131812 2215116كآ ممه 
دد عجعج لوعع رع عناعمركت للانا ثانا 1 
رع وتاصع ومطر مرك للطنا لآلا 11 


, 7711155 11نه 1255 10115_211218101535قظآ درت م1 __ 
,2122 1د دتوصه الادج دع ممع ماك لللناالالا 12 
, قعط تاط دعاط 2 ةصق عي 2 7مك للنا اانا 12 

2112 3 1جدع 7ط ظادالاالقظ ‏ نأاجره_م1__ 


للدالة 7 معاملات هم كالتالي : 


1 - عمزا3لاء|1تام! : اسم الملف أو اسم الديفيس المراد إنشائه أو فتحه .. 
وهنا نقوم بوضع اسم الارتباط الرمزن ©300لاكا ما اء760|1الا5 الذي يربط 
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المستخدم مع الكيرنل.. والاختصار "١١١"‏ سيجعل الدالة تصل إلي نطاف 
الديفيسز .. ومن ثم تصل إلي الديفيس المحدد بالاسم. 


2 - 55عع086ع512ع01/10 : يحدد صلاحية الوصول .. ونعطي الصلاحية : 


ْ ع 1هللا _عتمعلاع6 ءه ممعه_عرتمعلرعه 
فذلك اللقراءة: أؤ الكنانة من وال الدتفس. 


3 - 1006اع0/5031 : يحدد نوع المشاركة الذي تريده للملف أو للديفيس .. 
إذا أعطيت لهذا المعامل الصفر .. فهذا يعني أن الملف أو الديفيس لن 
يتم مشاركته ولا يمكن القراءة فنحه إلا إذا انتهيت من المقبض أولا 
وأقلففة:. ويفكن اسمخدامر اف من الفيم الثالية أ الحمعةيينها : 


غأاطاعغرا_غ خم د_غا1] 
راطعكا_ غ4 !د_عا1]ا 
11كا/ئ/ا_ع خم ااد_عا1]ا 


4 - كعألاط1 1 أ1/4!لا 0560| : معامل اختياري وهو مؤشر إلي بنية 
5]لا118 117>_81الا550 تحدد إذا كان المقبض المعاد يورث إلي 
تطبيقات فرعية أم لا ؟ .. نهمل هذا المعامل ونضع ا الالاا. 


١ 
ردق‎ 


5180وم15 0/6360 : يحدد الفعل المراد اتخاذه إذا كان الملف أو 


الديفيس موجود من قبل او غير موحجود .. وللديفيسز يتم إعطاء هذا 
المعامل القيمة 1/6 | 15»اع_الاعغ02. 


6 - دعلا ط01/130580811 : يحدد خصائص ورايات للملف .. لا يهمنا كتيرا 
هذا المعامل هنا. 


١ 
٠.ل‎ 


لاع دام ماع 1 م : معامل اختياري يحدد مقبض لملف قالب له صلاحية 
القراءة ليتم اخذ خصائص هذا القالب للملف الحالي. 


وعند نجاح الدالة فتعود كما ذكرنا بمقبض للملف أو للديفيس ونقوم بنسخ 
هذا المقبض للمتغير 1©1166 .. وعند فشل الدالة تعود بالقيمة 
غلاام/ا_عارالال0_164ا1اق4/الاا! .. 


وعندما نريد إغلاق هذا المقبض .. نستخدم الدالةه ©1056301) مع تمرير 
قيمة المقبض إليها. 
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السطر 112 : نقوم باستدعاء الدالة (10)010ع1/اع0 والتي تستخدم 
لإرسال كود تحكم إلي الديفيس .. 


! 521251ننات 1016212821 221ل 1 الا باناناظ8 


ر2ج امنا نالا لق 1 

,5ه 1هجعطع درونات 1مك لللنالال1 12 
د فدهن ف 1م اع 1ف (لالاار ف 19 سه 
,2211112225122 1م لل 101 دور 

+ 1258111123 تالاج 1 219011(1ك أزهت_ناقاهم_ر 

, 81111215122 ندم لان لآلا 12_ 
ممع ناط عل مع م1 اانا لاط آزت_ناقنام_رر 


ممت 1عدع س1 21 لل 112017 نأطزت_:ئ120111__ 


للدالة 8 معاملات هم كالتالي : 


- [ 


١ 
ن]‎ 


١ 
رن‎ 


١ 
حل‎ 


١ 
ردق‎ 


١ 
0١ 


١ 
٠.ل‎ 


١ 
00 


ع6/اع10 : مقبض الديفيس الذي حصلنا عليه من دالةقع|ااعأاهعن). 


1/10017101-00 : كود التحكم المراد إرساله لهذا الديفيس. 


81 : مؤشر إلي مخزن المدخلات حيث يحتوي علي أي بيانات 
إدخال إضافية تريد تمريرها إلي الدريفر. 


1811512 : حجم مخزن المدخلات بالبايت. 


]نا 0008| : مؤشر إلي مخزن المخرجات حيث سيحتوي علي أي 
بيانات قام الدريفر بتمريرها للمستخدم. 


ع1512ع]]آلا8ألا70 : حجم مخزن المخرحات بالبايت. 


0 ناع]د5عالا8م| : مؤشر لمتغير سيحمل عدد البايتات المعادة في 
المعامل مألا 8أنا0م|. 


0 © : مؤشر إلي بنية رماعغ 0١/1/6820‏ تستخدم لعمليات 
التزامن ولن نستخدمها ونضع قيمتها ا الالاا. 
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وعند نجاح الدالة تعود بقيمة غير الصفر .. وعند فشلها تعود بالقيمقا انالا. 


عندما يتم إنشاء خدمة الدريفر في قاعدة البيانات .. يتم إنشاء مفتاح تسجيل 
لها ماسم الكدمة ؤناناتها في المسار التالى : 


5ع نا ١‏ لاع | ولاكاعلا1 14 ال )0 |_ لاعن 


والذقه يحتوف أرضا قلي اناك خميع الخدمات الفوهودة علي التظام 


03 لع ك د 


ماعط كعاتصبوع سبعالا لزلع عاط 
تان 1 دل" سداق امك 55 
عه غصم عداةم) ‏ مد_وعم . ادامععننزهها ملاع 
عامتلةئع م1 52_قاعما عنمة ل امام داح زظه] 20110 
ذلا لالالانانا0انالازنا ..,تا_طّعهع أنضارصت_يم ]يه 


كعنم إعه نل ناء؟ "اع لخصا ععماسا ا ...ع_دعيم طاأدععودس] زظه] 
ا تخناناناناناناناة“:نا ...نا_اعم تاد | به 
1 000100001 ...0_وععم عمم] يما 


| اناعد 
أة ادوع 


زيمكمدعر اممدع 5 1ص 
ا 1 34 . | آلا 4 


عامووقوع أمعع ع5 أاع دام امم امع سرت لاع اكتداع لل اافل»]_ اضف ا_كعمطتع لمصص ملم 


وكل حقل في الصورة السابقة تم التعرف عليه من قبل .. من الممكن عندما 
تقوم بعمل 0030لا للدريفر الا يتم حذف هذا المفتاح .. وبالتالي يمكن 
استخدام دوال 4881 3076لا متل 1030101161ل١‏ و ع0103010117لاألا لتحميل 


وإلغاء تحميل الدريفر بصورة يدوية من الريجستري. 





) خ11-2301021722 لاما دلا 1.1 5 1 الا 


الهج ومع رمت 1عزال[] 0101-11 111ل21 111 
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فقط يبقي لنا أن نوضح دوال 881 0/3006 الغير موثقة التي يمكن استخدامها 
في مود الفن:ة خدم او مود الكيرنل والتي ستحد لها مرجحح خارجي مخ 
صفحات الكتاب. 


كما ذكرنا من قبل أن لهذه الدوال مجموعات يسبقها حرفين أو ثلاثة اختصار 
يدل علي نوع المجموعة مثل : 


للا 01 آلآ : هي استدعاءات نظامية 5ا|3© 7(اعأو5لا5 معرفة داخل االاط و 
امكاومغ5 .. المكتبة الأولي ١ا5]0‏ توفر استدعاءات لتلك الدوال في مود 
المستخدم ©1100 /ع5لا والكيرنل .. بينما المكتبة التانية | |0105 توفر 
استدعاءات لتلك الدوال في مود الكيرنل. 


1 : الدوال التي تبدأ بهذا الأختصار فهي دوال /3]طنا 1106 -0ناه 
وهي مجموعة دوال متنوعة مفيدة للمستخدم متل : 

مجع لاع أجع 01 

5ع اع | 10 ع1[ اما 

ات 5119 


59 : ويفيد هذا الأختصار أن الدوال تستخدم للتنقيح مثل : 
1م02 
عا ]| 
أم 0020| 


1 : ويفيد أن الدوال تستخدم للتحميل لملفات ال58 مثل: 
اا 0110301 ا 
ااما030املا0ا 


وغيرها العديد من الدوال والمجموعات التي تنتظر من يستكشفها. 


ولله الحمد من قبل ومن بعد 
محمد فاروق 


أغسطس 2010 
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الفصلء الأوك 0 
التنقيح وأدوات مساعدة و مأو ودااعج] 

الفصل الثاني ددببببب11 000100101321202 000 

الفصام الثالث 00 

الفصل الرابع 0 


الفصل امسن ا ا ا ا 


الفصام السادسن 000000 1 1 1 1 1 1 1 1 1 اا 0 


البرمجة في مود الكيرنل 00 امامط 03م ع100/ا-اعمرع»ا 


